init
This commit is contained in:
65
docker_env/README.md
Normal file
65
docker_env/README.md
Normal file
@@ -0,0 +1,65 @@
|
||||
# docker 镜像打包
|
||||
|
||||
### 打包web基础Build包
|
||||
|
||||
~~~sh
|
||||
# 编译打包到本地
|
||||
docker build -f ./docker_env/web/DockerfileBuild -t registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-web:latest .
|
||||
# 上传到阿里云仓库
|
||||
docker push registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-web:latest
|
||||
|
||||
~~~
|
||||
|
||||
### 打包Backend基础Build包
|
||||
|
||||
~~~sh
|
||||
# 编译打包到本地
|
||||
docker build -f ./docker_env/django/DockerfileBuild -t registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-backend:latest .
|
||||
# 上传到阿里云仓库
|
||||
docker push registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-backend:latest
|
||||
~~~
|
||||
|
||||
### 运行前端
|
||||
|
||||
~~~
|
||||
docker build -f ./docker_env/web/Dockerfile -t dvadmin-pro-web .
|
||||
~~~
|
||||
|
||||
### 运行后端
|
||||
|
||||
~~~
|
||||
docker build -f ./docker_env/django/Dockerfile -t dvadmin-pro-django .
|
||||
~~~
|
||||
|
||||
### 运行celery
|
||||
|
||||
~~~
|
||||
docker build -f ./docker_env/celery/Dockerfile -t dvadmin-pro-celery .
|
||||
~~~
|
||||
|
||||
## docker-compose 运行
|
||||
|
||||
~~~
|
||||
# 先安装docker-compose (自行百度安装),执行此命令等待安装,如有使用celery插件请打开docker-compose.yml中celery 部分注释
|
||||
docker-compose up -d
|
||||
# 初始化后端数据(第一次执行即可)
|
||||
docker exec -ti dvadmin-django bash
|
||||
python manage.py makemigrations
|
||||
python manage.py migrate
|
||||
python manage.py init -y
|
||||
exit
|
||||
|
||||
前端地址:http://127.0.0.1:8080
|
||||
后端地址:http://127.0.0.1:8000
|
||||
# 在服务器上请把127.0.0.1 换成自己公网ip
|
||||
账号:superadmin 密码:admin123456
|
||||
|
||||
# docker-compose 停止
|
||||
docker-compose down
|
||||
# docker-compose 重启
|
||||
docker-compose restart
|
||||
# docker-compose 启动时重新进行 build
|
||||
docker-compose up -d --build
|
||||
|
||||
~~~
|
||||
|
||||
7
docker_env/celery/Dockerfile
Normal file
7
docker_env/celery/Dockerfile
Normal file
@@ -0,0 +1,7 @@
|
||||
FROM registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-backend:latest
|
||||
WORKDIR /backend
|
||||
COPY ./backend/ .
|
||||
RUN awk 'BEGIN { cmd="cp -i ./conf/env.example.py ./conf/env.py "; print "n" |cmd; }'
|
||||
RUN python3 -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ -r requirements.txt
|
||||
CMD ["celery", "-A", "application", "worker", "-B", "--loglevel=info"]
|
||||
|
||||
6
docker_env/django/Dockerfile
Normal file
6
docker_env/django/Dockerfile
Normal file
@@ -0,0 +1,6 @@
|
||||
FROM registry.cn-zhangjiakou.aliyuncs.com/dvadmin-pro/dvadmin3-base-backend:latest
|
||||
WORKDIR /backend
|
||||
COPY ./backend/ .
|
||||
RUN awk 'BEGIN { cmd="cp -i ./conf/env.example.py ./conf/env.py "; print "n" |cmd; }'
|
||||
RUN python3 -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ -r requirements.txt
|
||||
CMD ["/backend/docker_start.sh"]
|
||||
6
docker_env/django/DockerfileBuild
Normal file
6
docker_env/django/DockerfileBuild
Normal file
@@ -0,0 +1,6 @@
|
||||
FROM python:3.10-alpine
|
||||
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
||||
RUN apk update && apk add bash bash-doc bash-completion git freetds-dev jpeg-dev linux-headers mysql-client mariadb-dev build-base libffi-dev openssl-dev zlib-dev bzip2-dev pcre-dev ncurses-dev readline-dev tk-dev postgresql-dev
|
||||
WORKDIR /backend
|
||||
COPY ./backend/requirements.txt .
|
||||
RUN python3 -m pip install -i https://mirrors.aliyun.com/pypi/simple/ -r requirements.txt
|
||||
33
docker_env/mysql/conf.d/my.cnf
Normal file
33
docker_env/mysql/conf.d/my.cnf
Normal file
@@ -0,0 +1,33 @@
|
||||
[mysql]
|
||||
#设置mysql客户端默认字符集
|
||||
default-character-set=utf8
|
||||
socket=/var/run/mysql/mysql.sock
|
||||
|
||||
|
||||
[mysqld]
|
||||
# skip-grant-tables
|
||||
#mysql5.7以后的不兼容问题处理
|
||||
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
|
||||
datadir=/var/lib/mysql
|
||||
socket=/var/run/mysql/mysql.sock
|
||||
|
||||
# Disabling symbolic-links is recommended to prevent assorted security risks
|
||||
symbolic-links=0
|
||||
# Settings user and group are ignored when systemd is used.
|
||||
# If you need to run mysqld under a different user or group,
|
||||
# customize your systemd unit file for mariadb according to the
|
||||
# instructions in http://fedoraproject.org/wiki/Systemdd
|
||||
#允许最大连接数
|
||||
max_connections=1000
|
||||
#服务端使用的字符集默认为8比特编码的latin1字符集
|
||||
character-set-server=utf8
|
||||
#创建新表时将使用的默认存储引擎
|
||||
default-storage-engine=INNODB
|
||||
lower_case_table_names=1
|
||||
max_allowed_packet=16M
|
||||
#设置时区
|
||||
default-time_zone='+8:00'
|
||||
|
||||
[mysqld_safe]
|
||||
log-error=/var/log/mariadb/mariadb.log
|
||||
pid-file=/var/run/mariadb/mariadb.pid
|
||||
5
docker_env/mysql/launch.sh
Normal file
5
docker_env/mysql/launch.sh
Normal file
@@ -0,0 +1,5 @@
|
||||
cur_path=`pwd`
|
||||
docker rm mysql
|
||||
# docker pull mysql:5.7
|
||||
# docker pull mysql:5.5
|
||||
docker run -p 3306:3306 --privileged=true --name mysql -v $cur_path/logs:/logs -v $cur_path/data:/var/lib/mysql -v $cur_path/conf.d/my.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf -v $cur_path/run/:/var/run/mysql -e MYSQL_ROOT_PASSWORD=q1w2e3r4 -d mysql:5.7
|
||||
33
docker_env/nginx/my.conf
Normal file
33
docker_env/nginx/my.conf
Normal file
@@ -0,0 +1,33 @@
|
||||
server {
|
||||
listen 8080;
|
||||
server_name localhost;
|
||||
client_max_body_size 100M;
|
||||
location / {
|
||||
proxy_set_header Host $http_host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
proxy_set_header X-Forwarded-Proto https;
|
||||
set_real_ip_from 0.0.0.0/0;
|
||||
real_ip_header X-Forwarded-For;
|
||||
root /usr/share/nginx/html;
|
||||
index index.html index.php index.htm;
|
||||
}
|
||||
|
||||
location /api/ {
|
||||
proxy_http_version 1.1;
|
||||
proxy_set_header Host $http_host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
proxy_set_header X-Nginx-Proxy true;
|
||||
set_real_ip_from 0.0.0.0/0;
|
||||
proxy_set_header Upgrade $http_upgrade;
|
||||
proxy_set_header Connection "upgrade";
|
||||
proxy_connect_timeout 600s;
|
||||
proxy_read_timeout 600s;
|
||||
proxy_send_timeout 600s;
|
||||
real_ip_header X-Forwarded-For;
|
||||
rewrite ^/api/(.*)$ /$1 break; #重写
|
||||
proxy_pass http://177.8.0.12:8000/; # 设置代理服务器的协议和地址
|
||||
}
|
||||
}
|
||||
24
docker_env/redis/redis.conf
Normal file
24
docker_env/redis/redis.conf
Normal file
@@ -0,0 +1,24 @@
|
||||
### 指定redis绑定的主机地址,注释掉这部分,使redis可以外部访问
|
||||
# bind 127.0.0.1 -::1
|
||||
### 指定访问redis服务端的端口
|
||||
port 6379
|
||||
### 指定客户端连接redis服务器时,当闲置的时间为多少(如300)秒时关闭连接(0表示禁用)
|
||||
timeout 0
|
||||
### 默认情况下,Redis不作为守护进程运行。如果需要,请使用“yes”
|
||||
daemonize no
|
||||
### 给redis设置密码,不需要密码的话则注释
|
||||
# requirepass dvadmin
|
||||
### 开启redis持久化,默认为no
|
||||
appendonly yes
|
||||
### 防止出现远程主机强迫关闭了一个现有的连接的错误 默认是300
|
||||
tcp-keepalive 300
|
||||
### 指定redis数据库的日志级别,常用的日志级别有debug、verbose、notice、warning,不进行修改的情况下默认的是notice
|
||||
loglevel notice
|
||||
### 指定redis数据库多长时间内(s)有多少次(c)更新操作时就把缓存中的数据同步到本地库,比如:save 600 2,指的是10分钟内有2次更新操作,就同步到本地库
|
||||
save 600 2
|
||||
### 指定redis的最大内存。由于Redis 在启动时会把数据加载到内存中,当数据达到最大内存时,redis会自动把已经到期和即将到期的key值。所以可以根据需求调整自己的所需的最大内存
|
||||
maxmemory 500mb
|
||||
### 设置了maxmemory的选项,redis内存使用达到上限。可以通过设置LRU算法来删除部分key,释放空间。默认是按照过期时间的,如果set时候没有加上过期时间就会导致数据写满maxmemory
|
||||
maxmemory-policy volatile-lru
|
||||
### 设置外部网络连接redis服务,开启需配置bind ip或者设置访问密码,关闭此时外部网络可以直接访问
|
||||
# protected-mode yes
|
||||
9
docker_env/web/Dockerfile
Normal file
9
docker_env/web/Dockerfile
Normal file
@@ -0,0 +1,9 @@
|
||||
FROM node:16.19-alpine
|
||||
WORKDIR /web/
|
||||
COPY web/. .
|
||||
RUN yarn install
|
||||
RUN yarn build
|
||||
|
||||
FROM nginx:alpine
|
||||
COPY ./docker_env/nginx/my.conf /etc/nginx/conf.d/my.conf
|
||||
COPY --from=0 /web/dist /usr/share/nginx/html
|
||||
4
docker_env/web/DockerfileBuild
Normal file
4
docker_env/web/DockerfileBuild
Normal file
@@ -0,0 +1,4 @@
|
||||
FROM node:16.19-alpine
|
||||
WORKDIR /
|
||||
COPY ./web/package.json .
|
||||
RUN npm install -g yarn
|
||||
Reference in New Issue
Block a user