Browse Source

Merge branch 'develop' of https://git.yoqi.me/github/github-actions-creator into develop

liuyuqi-dellpc 10 months ago
parent
commit
5436bd96f0

+ 6 - 91
README.md

@@ -12,98 +12,9 @@
 
 ## 前言
 
-本项目总结各语言,场景使用构建配置,包括github action,gitlab ci, jenkins, travis ci, circle ci, drone ci, teamcity, bamboo, codeship, semaphore, buildkite, wercker, screwdriver, concourse, gocd, codefresh, buddy, shippable, bitrise, buddy, azure devops, aws codebuild, google cloud build, codebuild, codepipeline, codecommit, codeartifact, codeg 等等
-
-github action 可以替代 ci/cd 持续集成,比国内各平台基于 Gitlab/Jenkins 要好多了,配置简单。国内 coding.net 良心私有项目可以用之替代github 。
-
-GitHub action 基于 yaml 语法,超级简单,但是 github steps 构建每个步骤不同,有一些action概念,关键词。本项目将基于自身项目架构经验,做一个模板文件,小修改即可立马使用。
-
-## 详情
-
-
-**runs-on** **可选:**
-
-| **名称**                                       | [已安装](https://github.com/actions/virtual-environments/blob/master/images/linux/Ubuntu1804-README.md) |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-| windows-2019                                   | docker/vs   2019/**android**/ruby/git/go/php/.net/minGW/miniconda/Alibaba Cloud CLI |
-| **ubuntu-latest** or   ubuntu-18.04   ubuntu-16.04 | docker/kubect/php/python/java/**android**/zip/.net/powershell/mysql/ms   sql/nodejs/webpack/yarn/gradle/maven/ant/ |
-| macos-latest or   macos-10.15                  | php/python/go/java/yarn/git/**xcode**/android                |
-
-### **azure 部分**
-
-关于 azure 云平台配合 github 相关 CI/CD配置。
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-| azure\.github\workflow\deploy-app-to-azure.yml | 部署resources app到azure  |
-| azure\.github\workflow\set-up-azure-resources.yml                  |  设置resources资源                |
-
-### **Vue 部分**
-
-使用 github action 自动构建/部署 Vue 项目。
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-|  |   |
-
-
-**Python 部分**
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-|  |   |
-
-
-
-**Go 部分**
-
-使用 github action 编译/发布 go 项目,以及使用 go web 功能。
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-|  |   |
-
-
-
-**PHP 部分**
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-|  |   |
-
-
-**Java 部分**
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-|  |   |
-
-
-**Android 部分**
-
-本项目刚启动时候,很多 android 使用 github action 自动构建的很少,本项目将归纳基于 eclipse 和 android studio 等开发的 android 项目使用 github action 自动构建方案。
-
-注意: 使用 eclipse IDE 开发的 andorid 项目,其实采用的是 ant 构建。而采用 android studio IDE 开发的项目采用的是 gradle 构建。
-
-| **位置**                                       | 描述 |
-| ---------------------------------------------- | ------------------------------------------------------------ |
-| android-studio\.github\workflows\main.yml |  默认 android studio 开发的项目采用这个 action |
-| android-eclipse\.github\workflows\main.yml |  采用 eclipse 开发的采用这个 action |
-
-
-20 年 vscode 开源的容器demo项目,修改为国内镜像。如今,使用通用镜像即可。
-```
-git clone https://github.com/Microsoft/vscode-remote-try-node
-git clone https://github.com/Microsoft/vscode-remote-try-python
-git clone https://github.com/Microsoft/vscode-remote-try-go
-git clone https://github.com/Microsoft/vscode-remote-try-java
-git clone https://github.com/Microsoft/vscode-remote-try-dotnetcore
-git clone https://github.com/Microsoft/vscode-remote-try-php
-git clone https://github.com/Microsoft/vscode-remote-try-rust
-git clone https://github.com/Microsoft/vscode-remote-try-cpp
-
-```
+本项目最初是整理各种语言的项目使用 github action。后续添加 github ci/cd, jenkins 等平台自动构建脚本,后续又陆续添加了基于 vscode 的云 IDE 环境配置脚本,docker 脚本,陆续将其他不再使用的 docker-images 项目整合到本项目中。
 
+包括 github action, gitlab ci, jenkins, travis ci, circle ci, drone ci, teamcity, bamboo, codeship, semaphore, buildkite, wercker, screwdriver, concourse, gocd, codefresh, buddy, shippable, bitrise, buddy, azure devops, aws codebuild, google cloud build, codebuild, codepipeline, codecommit, codeartifact, codeg 等等
 
 
 ## License
@@ -113,6 +24,10 @@ Copyright (c) 2021 [liuyuqi.gov@msn.cn](mailto:liuyuqi.gov@msn.cn). All rights r
 Licensed under the [Apache 2.0](LICENSE.md) license.
 
 
+## Reference
+
+[github-actions-creator 文档](https://wiki.yoqi.me/github-actions-creator/#/)
+
 ## Reference
 
 - [docs](https://wiki.yoqi.me/github-actions-creator/#/)

+ 3 - 1
android/android-eclipse/ Dockerfile

@@ -24,4 +24,6 @@ RUN mkdir -p /root/.android && \
     touch /root/.android/repositories.cfg && \
     sdkmanager --update
 
-CMD ["/bin/bash" ,"-c" ,"while true;do echo hello docker;sleep 1;done"]
+CMD ["/bin/bash" ,"-c" ,"while true;do echo hello docker;sleep 1;done"]
+
+

+ 31 - 0
docker/db/mariadb/Dockerfile

@@ -0,0 +1,31 @@
+FROM bitnami/mariadb:10.3
+
+USER root
+
+RUN mv /etc/apt/sources.list /etc/apt/sources.list.bak
+COPY buster.sources.list /etc/apt/sources.list
+
+RUN apt-get update && \
+    apt-get install -y curl git unzip vim wget && \
+    apt-get install -y locales kde-l10n-zhcn && \
+    apt-get clean && \
+    rm -rf /var/lib/apt/lists/*
+
+RUN sed -i 's/# zh_CN.UTF-8 UTF-8/zh_CN.UTF-8 UTF-8/g' /etc/locale.gen
+
+RUN locale && locale-gen "zh_CN.UTF-8"
+
+# Set environment variables.
+ENV LANG=zh_CN.UTF-8 \
+    LANGUAGE=zh_CN:zh:en_US:en \
+    LC_ALL=zh_CN.UTF-8 \
+    TZ=Asia/Shanghai \
+    DEBIAN_FRONTEND="noninteractive" \
+    TERM=xterm
+
+RUN ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \
+    echo $TZ > /etc/timezone && \
+    dpkg-reconfigure --frontend noninteractive tzdata && \
+    dpkg-reconfigure --frontend noninteractive locales
+
+USER 1001

+ 9 - 0
docker/db/mariadb/buster.sources.list

@@ -0,0 +1,9 @@
+deb http://mirrors.163.com/debian/ buster main non-free contrib
+deb http://mirrors.163.com/debian/ buster-updates main non-free contrib
+deb http://mirrors.163.com/debian/ buster-backports main non-free contrib
+deb http://mirrors.163.com/debian-security/ buster/updates main non-free contrib
+
+deb-src http://mirrors.163.com/debian/ buster main non-free contrib
+deb-src http://mirrors.163.com/debian/ buster-updates main non-free contrib
+deb-src http://mirrors.163.com/debian/ buster-backports main non-free contrib
+deb-src http://mirrors.163.com/debian-security/ buster/updates main non-free contrib

+ 3 - 0
docker/db/mongo-express/Dockerfile

@@ -0,0 +1,3 @@
+FROM mongo-express
+
+EXPOSE 8081

+ 31 - 0
docker/db/mongo-express/docker-compose.debug.yml

@@ -0,0 +1,31 @@
+version: '3.4'
+
+services:
+
+  mongo:
+    image: registry.cn-hangzhou.aliyuncs.com/kennylee/mongo-express
+    container_name: "mongo-express"
+    restart: always
+    # env_file: .env
+    environment:
+      - MONGO_INITDB_ROOT_USERNAME=root
+      - MONGO_INITDB_ROOT_PASSWORD=example
+    volumes:
+      - mongo-data:/data/db
+    networks:
+      - infisical-dev
+    ports:
+      - "27017:27017"
+    logging:
+      driver: 'json-file'
+      options:
+        max-size: '30m'
+        max-file: '1'
+
+volumes:
+  mongo-data:
+
+
+networks:
+  infisical-dev:
+    driver: bridge

+ 36 - 0
docker/db/mongo/Dockerfile

@@ -0,0 +1,36 @@
+# see also: https://github.com/docker-library/mongo/blob/21869963911a74ccc13697c3ad50cdc23cc79b15/4.1/Dockerfil
+FROM mongo:4.1.1-xenial
+RUN sed -i 's/archive.ubuntu.com/mirrors.163.com/g' /etc/apt/sources.list
+
+# Install.
+RUN \
+    apt-get update && \
+    apt-get -y upgrade && \
+    apt-get install -y curl git unzip vim wget iputils-ping && \
+    apt-get install -y language-pack-zh-hans && \
+    apt-get install -y tzdata && \
+    rm -rf /var/lib/apt/lists/*
+
+RUN locale
+
+# Set environment variables.
+ENV HOME /root
+ENV LANG=zh_CN.UTF-8\
+    LANGUAGE=zh_CN:zh:en_US:en\
+    LC_ALL=zh_CN.UTF-8\
+    TZ=Asia/Shanghai\
+    TERM=xterm
+
+RUN ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \
+    echo $TZ > /etc/timezone && \
+    dpkg-reconfigure --frontend noninteractive tzdata
+
+# Define working directory.
+WORKDIR $HOME
+
+VOLUME /data/db /data/configdb
+
+ENTRYPOINT ["docker-entrypoint.sh"]
+
+EXPOSE 27017
+CMD ["mongod"]

+ 8 - 1
docker/db/mongo/docker-compose.debug.yml

@@ -14,7 +14,14 @@ services:
       - mongo-data:/data/db
     networks:
       - infisical-dev
-
+    ports:
+      - "27017:27017"
+    logging:
+        driver: 'json-file'
+        options:
+            max-size: '30m'
+            max-file: '1'
+            
 volumes:
   mongo-data:
 

+ 32 - 0
docker/db/mysql/Dockerfile

@@ -0,0 +1,32 @@
+FROM mysql:5.7.33
+RUN mv /etc/apt/sources.list /etc/apt/sources.list.bak
+COPY buster.sources.list /etc/apt/sources.list
+
+RUN apt-get update && \
+    apt-get install -y curl git unzip vim wget && \
+    apt-get install -y locales kde-l10n-zhcn && \ 
+    apt-get clean && \
+    rm -rf /var/lib/apt/lists/*
+
+RUN sed -i 's/# zh_CN.UTF-8 UTF-8/zh_CN.UTF-8 UTF-8/g' /etc/locale.gen
+
+RUN locale && locale-gen "zh_CN.UTF-8"
+
+# Set environment variables.
+ENV LANG=zh_CN.UTF-8 \
+    LANGUAGE=zh_CN:zh:en_US:en \
+    LC_ALL=zh_CN.UTF-8 \
+    TZ=Asia/Shanghai \
+    DEBIAN_FRONTEND="noninteractive" \
+    TERM=xterm
+
+RUN ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \
+    echo $TZ > /etc/timezone && \        
+    dpkg-reconfigure --frontend noninteractive tzdata && \
+    dpkg-reconfigure --frontend noninteractive locales
+
+COPY my.cnf /etc/mysql/my.cnf
+RUN mkdir -p /etc/mysql/mysql-my.conf.d/
+
+EXPOSE 3306
+CMD ["mysqld"]

+ 0 - 0
docker/db/mysql/my.cnf


+ 20 - 0
docker/db/oracle-xe-11g/docker-compose.yml

@@ -0,0 +1,20 @@
+version: '2'
+services:
+    app:
+        image: registry.cn-hangzhou.aliyuncs.com/kennylee/oracle-xe-11g
+        ports: 
+            - "1521:1521"
+            - "1522:22"
+        container_name: oracle-xe-11g
+        restart: always
+        environment:
+            - TZ=Asia/Shanghai
+            - ORACLE_ALLOW_REMOTE=true
+        shm_size: 2g
+        volumes:
+            - ./data/:/u01/data/:z
+        logging:
+            driver: 'json-file'
+            options:
+                max-size: '30m'
+                max-file: '1'

+ 19 - 0
docker/db/postgresql/docker-compose.yml

@@ -0,0 +1,19 @@
+version: '2'
+
+services:
+  postgresql:
+    image: 'registry.cn-hangzhou.aliyuncs.com/kennylee/postgresql:12.4'
+    container_name: "postgresql"
+    ports:
+      - '5432:5432'
+    volumes:
+      - './data/data:/bitnami/postgresql'
+      - './data/conf:/bitnami/postgresql/conf/'
+    environment:
+      - POSTGRESQL_PASSWORD=password123456
+    restart: on-failure
+    logging:
+      driver: 'json-file'
+      options:
+        max-size: '12m'
+        max-file: '5'

+ 6 - 1
docker/db/redis/docker-compose.debug.yml

@@ -13,7 +13,12 @@ services:
       - redis_data:/data
     networks:
       - infisical-dev
-
+    # command: [ "redis-server", "/usr/local/etc/redis/redis.conf" ]
+    logging:
+      driver: 'json-file'
+      options:
+        max-size: '30m'
+        max-file: '1'
   redis-commander:
     container_name: infisical-dev-redis-commander
     image: rediscommander/redis-commander:latest

+ 0 - 1
docs/cicd/auzre_pipeline.md

@@ -3,7 +3,6 @@
 Azure Pipelines 和 Github Action一样,支持各种语言,各种平台(windows,linux,mac),自动部署到各云平台,开源项目10个免费无线分钟数。
 
 
-
 ## Usage
 
 项目添加 `.azure-pipelines/azure-pipelines.yml`,

+ 0 - 51
docs/dev/others.md

@@ -12,54 +12,3 @@ mkdir -p php-demo
 chmod 777 php-demo && cd php-demo
 docker run --rm -it -w /var/www/html -v $(pwd):/var/www/html -p 8000:8000 groovy:jdk17-alpine /bin/bash
 cd /var/www/html
-
-## 数据库
-
-mysql
-
-
-
-## 服务器
-
-apache
-
-jetty
-
-
-
-tomcat
-
-在部署 jsp 项目需要用到,项目打 war 包,放入 tomcat web目录,配置好运行:
-
-```
-# 新建项目
-mvn archetype:generate \
-  -DgroupId=com.example \
-  -DartifactId=my-project \
-  -DarchetypeArtifactId=maven-archetype-quickstart \
-  -DinteractiveMode=false
-
-mvn archetype:generate \
-    -DgroupId=com.example \
-    -DartifactId=my-jsp-project \
-    -DarchetypeArtifactId=maven-archetype-webapp \
-    -DinteractiveMode=false
-
-# 编译项目
-mvn package
-
-# 部署项目
-docker run -it --rm -p 8888:8080 -v $(pwd)/target:/usr/local/tomcat/webapps tomcat:9.0
-
-# 访问 http://localhost:8888/my-project
-
-```
-
-
-## Rust
-
-docker run -d --privileged -p 58888:8080 jklincn/rust-os
-
-访问: http://localhost:58888 开启vscode开发 rust
-
-

+ 3 - 3
docs/dev/python.md

@@ -1,13 +1,13 @@
 # python
 
-如项目需要在 python3.8 环境下开发,可以使用以下方式:
+如项目需要在 python3.8 环境下开发,可以使用以下方式:
 
 ```
 docker run --rm -it -v /workspace:/app python:3.8 /bin/bash
 
 ```
 
-python环境编译较慢,为此最佳的方式pull镜像
+python环境编译较慢,为此最佳的方式 pull 镜像
 
 
 
@@ -57,4 +57,4 @@ RUN apt-get update && apt-get install -y wget unzip openssh-server
 # 指定字符集支持命令行输入中文(根据需要选择字符集)
 ENV LANG C.UTF-8
 ENV LANGUAGE C.UTF-8
-```
+```

+ 3 - 1
docs/ide/codespaces.md

@@ -1,6 +1,8 @@
 # Codespaces
 
-Github 60小时/月免费开发环境,支持远程容器开发,Vscode。注意需要及时删除环境,不用磁盘也会累积计算。
+Github 60 小时/月免费开发环境,支持 VSCode 远程容器开发。
+
+**注意需要及时删除环境,不用磁盘也会累积计算。**
 
 ## 使用
 

+ 17 - 6
docs/ide/coding.md

@@ -1,19 +1,20 @@
-# coding
+# coding.net
 
 coding 提供两个开发环境:
 
 * 云原生开发环境
 * cloudstudio
 
-前者免费 160 小时/月,后者免费 3000分钟 = 50小时/月。
+前者免费 160 小时/月,后者免费 3000 分钟 = 50小时/月。
 
 
 ## 远程开发
 
-在本地通过 repo_sync tools v1.12,快速创建项目,项目推到云端,然后在云端开发。
+在本地通过 repo_sync tools v1.12,快速创建 coding.net 项目,项目推到云端,然后在云端开发。
 
-添加 `.coding-ci.yml` 以及 `.ide/Dockerfile`配置文件
+添加 `.coding-ci.yml` 以及 `.ide/Dockerfile`配置文件:
 
+`.coding-ci.yml`
 ```
 $:
   api_trigger_vscode:
@@ -33,12 +34,22 @@ $:
 
 ```
 
-节省cpu,这里node开发,php开发等配置cpu第,app开发等配置cpu高。
+为了节省 cpu 资源,这里 node/php 开发等配置 cpu 为1 即可,app开发等配置cpu 4-8 个。
+
+`.ide/Dockerfile`
+
+```
+FROM sift-docker.pkg.coding.net/flutter-team/dev-container/dev-allinone:1.0.11-flutter
+```
+
+这个镜像源码在 flutter\.ide\Dockerfile-Allinone-flutter 中, 包含了 flutter, node, php, go, python, java, rust, ruby, c/c++, .net, dart 等开发环境,方便快速编译项目。
 
 
 ## cloudstudio
 
-cloudstudio 是独立的产品,一般都是基于模板快速新建开发环境,当然也可以手动选择项目新建环境。只能选择系统开发环境。主要用户数据分析。
+cloudstudio 是独立的产品,一般都是基于模板快速新建开发环境,当然也可以手动选择项目新建环境。只能选择系统开发环境。主要用来做数据分析。
+
+
 
 
 ## ci/cd

+ 12 - 1
docs/ide/gitpod.md

@@ -1,6 +1,8 @@
 # gitpod
 
-Gitpod是最早的远程开发平台,配置较高,50 小时/月免费,很容易用完。添加配置文件 `.gitpod.yml` 和 `.gitpod.Dockerfile`,内容如下:
+Gitpod 是最早的远程开发平台,配置较高,50 时/月免费,很容易用完。添加配置文件 `.gitpod.yml` 和 `.gitpod.Dockerfile`,内容如下:
+
+`.gitpod.yml` 
 
 ```yaml
 image:
@@ -16,9 +18,18 @@ tasks:
         command: npm run dev
 ```
 
+配置文件主要设置 启动命令,安装依赖等。
 
+ `.gitpod.Dockerfile`
 
+```
+FROM gitpod/workspace-full:latest
 
+USER gitpod
 
+RUN pip3 install pytest==4.4.2 mock pytest-testdox toml
+RUN npm i learnpack@0.1.14 -g && learnpack plugins:install learnpack-python@0.0.35
 
+```
 
+这里使用了 gitpod 官方的镜像,安装了 python 和 nodejs 的依赖,可以对特定语言项目添加环境。

+ 0 - 16
dotnet/Dockerfile

@@ -1,17 +1 @@
-FROM node:lts-alpine as base
-RUN apk add --no-cache tini
-ENV NODE_ENV=production
-USER  node
-WORKDIR /app
-COPY package*.json ./
-RUN npm install
-COPY . .
-RUN chown -R appuser:appgroup /app
-EXPOSE 8080
 
-FROM base as builder
-
-
-FROM base as runner
-
-CMD [ "npm", "start" ]

+ 22 - 0
go/Dockerfile

@@ -1,4 +1,26 @@
 FROM golang:1.19 as builder
+
+
+RUN echo "deb http://mirrors.163.com/debian/ jessie main non-free contrib\n\
+    deb http://mirrors.163.com/debian/ jessie-updates main non-free contrib\n\
+    deb http://mirrors.163.com/debian/ jessie-backports main non-free contrib\n\
+    deb-src http://mirrors.163.com/debian/ jessie main non-free contrib\n\
+    deb-src http://mirrors.163.com/debian/ jessie-updates main non-free contrib\n\
+    deb-src http://mirrors.163.com/debian/ jessie-backports main non-free contrib\n\
+    deb http://mirrors.163.com/debian-security/ jessie/updates main non-free contrib\n\
+    deb-src http://mirrors.163.com/debian-security/ jessie/updates main non-free contrib\n\
+    deb http://ftp.cn.debian.org/debian jessie main" > /etc/apt/sources.list
+
+# install gcc
+RUN apt-get update && apt-get install -y --no-install-recommends \
+    g++ \
+    gcc \
+    libc6-dev \
+    make \
+    pkg-config \
+    && apt-get install -y curl git unzip vim iputils-ping wget \
+    && rm -rf /var/lib/apt/lists/*
+
 WORKDIR /workspaces
 COPY . ./
 ENV GOPROXY=https://goproxy.cn,direct

+ 5 - 0
go/docker-compose.debug.yml

@@ -11,3 +11,8 @@ services:
     ports:
       - 3000:3000
       - 5005:5005
+    logging:
+      driver: 'json-file'
+      options:
+        max-size: '10m'
+        max-file: '1'

+ 26 - 5
java/Dockerfile-build

@@ -1,18 +1,35 @@
 # FROM openjdk:11 as builder
 FROM openjdk:8 as builder
 
-ENV MAVEN_VERSION=3.9.5 \
+ARG MAVEN_VERSION=3.9.5 \
     GRADLE_VERSION=7.3.3
 
+ARG GRADLE_DOWNLOAD_SHA256=98bd5fd2b30e070517e03c51cbb32beee3e2ee1a84003a5a5d748996d4b1b915
+
 # # install gradle
-RUN wget https://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin.zip -P /tmp
-RUN unzip -d /opt/gradle /tmp/gradle-*.zip && rm -rf /tmp/gradle-*.zip
+RUN set -o errexit -o nounset \
+    && echo "Downloading Gradle" \
+    && wget -q "https://services.gradle.org/distributions/gradle-${GRADLE_VERSION}-bin.zip" -P /tmp/gradle.zip \
+    \
+    && echo "Checking download hash" \
+    && echo "${GRADLE_DOWNLOAD_SHA256} *gradle.zip" | sha256sum -c - \
+    \
+    && echo "Installing Gradle" \
+    && unzip -d /opt/gradle /tmp/gradle-*.zip && rm -rf /tmp/gradle-*.zip \
+    && ln -s "${GRADLE_HOME}/bin/gradle" /usr/bin/gradle
+
 ENV GRADLE_HOME=/opt/gradle/gradle-${GRADLE_VERSION}
 ENV PATH=$PATH:$GRADLE_HOME/bin
 
 # install maven
-RUN wget https://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/${MAVEN_VERSION}/binaries/apache-maven-${MAVEN_VERSION}-bin.zip -P /tmp
-RUN unzip -d /opt/maven /tmp/apache-maven-*.zip
+RUN set -o errexit -o nounset \
+    && echo "Downloading Maven" \
+    && wget -q "https://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/${MAVEN_VERSION}/binaries/apache-maven-${MAVEN_VERSION}-bin.zip" -P /tmp \
+    \
+    && echo "Installing Maven" \
+    && unzip -d /opt/maven /tmp/apache-maven-*.zip && rm -rf /tmp/apache-maven-*.zip \
+    && ln -s "${MAVEN_HOME}/bin/mvn" /usr/bin/mvn
+
 ENV MAVEN_HOME=/opt/maven/apache-maven-${MAVEN_VERSION}
 ENV PATH=$PATH:$MAVEN_HOME/bin
 
@@ -20,4 +37,8 @@ LABEL email="liuyuqi<liuyuqi.gov@msn.cn>"
 WORKDIR /workspaces
 # RUN mvn package
 VOLUME [ "/workspaces" ]
+
+ENV USER_HOME_DIR="/home/gradle"
+ENV MAVEN_CONFIG "$USER_HOME_DIR/.m2"
+
 CMD [ "/bin/bash" ]

+ 29 - 0
java/README.md

@@ -0,0 +1,29 @@
+# Java
+
+Dockerfile-build 包含 maven,gradle,ant,java 等工具。
+
+Gradle本地库 `/home/gradle/.gradle`
+Maven本地仓库挂载 `/var/maven/repository`
+
+## Uage
+
+install java, gradle, maven, ant, etc.
+
+java version:
+- 8
+- 11
+- 14
+- 15
+- 16
+- 17
+
+gradle version:
+- 6.8.3
+- 7.0.2
+
+maven version:
+- 3.6.3
+
+ant version:
+- 1.10.9
+

+ 14 - 5
nodejs/Dockerfile

@@ -1,13 +1,22 @@
 FROM node:lts-alpine as base
-RUN apk add --no-cache tini
 
+RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
 
-FROM base as builder
-RUN npm config set registry http://registry.npm.taobao.org
-RUN npm install pnpm -g
+RUN set -o errexit -o nounset \
+    echo "Installing base package" \
+    && apk --no-cache update && apk --no-cache upgrade \
+    && apk add --no-cache curl bash tzdata tar unzip xz procps wget git openssh \
+    && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
+    echo "Asia/Shanghai" > /etc/timezone \
+    && apk add --no-cache tini \
+    && rm -fr /tmp/* /var/cache/apk/*
 
-FROM base as runner
 ENV NODE_ENV=production
+ENV LANG C.UTF-8
+ENV TZ Asia/Shanghai
+
+RUN npm install -g cnpm --registry=https://registry.npm.taobao.org
+
 USER  node
 WORKDIR /app
 COPY package*.json ./

+ 15 - 2
python/Dockerfile

@@ -1,7 +1,20 @@
-FROM python:3.8
+FROM python:3.12 as base
+
+LABEL email="liuyuqi<liuyuqi.gov@msn.cn>"
+# ENV key=value
 WORKDIR /app
 ADD . ./app
 RUN pip install -r requirements.txt
 
+FROM base as builder
+RUN pip install pyinstaller
+RUN pyinstaller -F -c demo.py
 
-CMD [ "python","app.py" ]
+FROM base as runner
+COPY --from=builder . /app/
+WORKDIR /app
+# EXPOSE 8080
+# ENTRYPOINT [ "executable" ]
+# VOLUME [ "/data" ]
+# CMD [ "/bin/bash" ]
+CMD [ "python","main.py" ]

+ 0 - 8
python/Dockerfile-build

@@ -1,8 +0,0 @@
-FROM python:3.8 as builder
-LABEL email="liuyuqi<liuyuqi.gov@msn.cn>"
-WORKDIR /workspaces
-
-# RUN pip install -r requirements.txt
-
-VOLUME [ "/workspaces" ]
-CMD [ "/bin/bash" ]

+ 0 - 13
python/Dockerfile-pyinstall

@@ -1,13 +0,0 @@
-FROM python:3.8 as base
-WORKDIR /app
-ADD . ./app
-RUN pip install -r requirements.txt
-
-
-FROM base as builder
-RUN pip install pyinstaller
-RUN pyinstaller -F -c demo.py
-
-FROM base as runner
-COPY --from=builder . /app/
-CMD [ "python", "main.py" ]

+ 0 - 6
python/backend/Dockerfile

@@ -1,6 +0,0 @@
-# Build stage
-FROM python:3.8
-
-WORKDIR /app
-
-CMD ["python", "main.py"]

+ 6 - 1
ruby/.gitpod.Dockerfile

@@ -1,8 +1,13 @@
 FROM gitpod/workspace-postgres
 USER gitpod
 
+WORKDIR /app
 # Install the Ruby version specified in '.ruby-version'
 COPY --chown=gitpod:gitpod .ruby-version /tmp
 RUN echo "rvm_gems_path=/home/gitpod/.rvm" > ~/.rvmrc
 RUN bash -lc "rvm reinstall ruby-$(cat /tmp/.ruby-version) && rvm use ruby-$(cat /tmp/.ruby-version) --default && gem install rails"
-RUN echo "rvm_gems_path=/workspace/.rvm" > ~/.rvmrc
+RUN echo "rvm_gems_path=/workspace/.rvm" > ~/.rvmrc
+
+# EXPOSE 8080
+# VOLUME [ "/data" ]
+CMD [ "/bin/bash" ]

+ 13 - 13
ruby/Dockerfile

@@ -1,17 +1,17 @@
-FROM node:lts-alpine as base
-RUN apk add --no-cache tini
-ENV NODE_ENV=production
-USER  node
-WORKDIR /app
-COPY package*.json ./
-RUN npm install
-COPY . .
-RUN chown -R appuser:appgroup /app
-EXPOSE 8080
+FROM 3.4-rc-alpine
+
 
-FROM base as builder
+# ENV key=value
+WORKDIR /app
 
+# Install Ruby and Rails
 
-FROM base as runner
+# Install the Ruby version specified in '.ruby-version'
+COPY --chown=gitpod:gitpod .ruby-version /tmp
+RUN echo "rvm_gems_path=/home/gitpod/.rvm" > ~/.rvmrc
+RUN bash -lc "rvm reinstall ruby-$(cat /tmp/.ruby-version) && rvm use ruby-$(cat /tmp/.ruby-version) --default && gem install rails"
+RUN echo "rvm_gems_path=/workspace/.rvm" > ~/.rvmrc
 
-CMD [ "npm", "start" ]
+# EXPOSE 8080
+# VOLUME [ "/data" ]
+CMD [ "/bin/bash" ]

+ 1 - 1
ruby/build.yml

@@ -12,6 +12,7 @@ jobs:
       matrix:
         node-version: [12.x]
     runs-on: ubuntu-latest
+    
     steps:
     - name: Check out branch
       uses: actions/checkout@v2
@@ -30,4 +31,3 @@ jobs:
         path: ${{ env.MINT_PATH }}
         key: ${{ runner.os }}-mint-${{ hashFiles('**/Mintfile') }}
         restore-keys: ${{ runner.os }}-mint-
-        

+ 3 - 2
ruby/docker-compose.debug.yml

@@ -1,8 +1,8 @@
 version: '3.4'
 
 services:
-  githubactionscreator:
-    image: githubactionscreator
+  ruby:
+    image: jianboy/ruby:2.5.1
     build:
       context: .
       dockerfile: ./Dockerfile
@@ -11,3 +11,4 @@ services:
     ports:
       - 3000:3000
       - 5005:5005
+    # volumes:

+ 2 - 0
rust/docker-compose.debug.yml

@@ -11,3 +11,5 @@ services:
     ports:
       - 3000:3000
       - 5005:5005
+
+