docker-compose安装与部署djnago+uwsgi+nginx+mysql+redis

一、安装docker-compose(docker安装请参与https://www.cnblogs.com/konglingxi/p/12378295.html

1.curl -L "https://get.daocloud.io/docker/compose/releases/download/1.25.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

2.chmod +x /usr/local/bin/docker-compose

3.docker-compose --version

4.yum install -y gcc libffi-devel python-devel openssl-devel

  

二、.部署django+uwsgi+nginx+mysql+redis

1、文件结构

docker-compose安装与部署djnago+uwsgi+nginx+mysql+redis

 2、cgy_docker/build/kcnet/Dockerfile

#定义该镜像使用的基础镜像为:python:3.7.4-stretch
FROM python:3.7.4-stretch
#定义容器的工作目录
WORKDIR /wwwroot
#拷贝pip安装项目所需要的包名称
COPY requirements.txt ./
#更新pip
RUN pip install --upgrade pip -i https://pypi.douban.com/simple/
#安装依赖包
RUN pip install -r requirements.txt -i https://pypi.douban.com/simple/
#开放的端口
EXPOSE 8000

3、cgy_docker/work/components/mysql/config/my.cnf

[client]
port    = 3306
socket  = /var/run/mysqld/mysqld.sock

[mysql]
prompt="u@mysqldb R:m:s [d]> "
no-auto-rehash

[mysqld]
##########################################NEED SET#################################################
#主数据库的id必须小于从数据库的id
server-id = 1
###########################################SET END################################################
user    = mysql
port    = 3306
basedir = /usr
datadir = /var/lib/mysql/
socket  = /var/run/mysqld/mysqld.sock
pid-file = mysqldb.pid
character-set-server = utf8mb4
skip_name_resolve = 1

#sql模式
sql_mode='strict_trans_tables,no_zero_in_date,error_for_division_by_zero,no_auto_create_user,no_engine_substitution'

#若你的MySQL数据库主要运行在*,请务必根据实际情况调整本参数
default_time_zone = "+8:00"

open_files_limit    = 65535
back_log = 1024
max_connections = 512
max_connect_errors = 1000000
table_open_cache = 1024
table_definition_cache = 1024
table_open_cache_instances = 64
thread_stack = 512K
external-locking = FALSE
max_allowed_packet = 32M
sort_buffer_size = 4M
join_buffer_size = 4M
thread_cache_size = 768
interactive_timeout = 600
wait_timeout = 600
tmp_table_size = 32M
max_heap_table_size = 32M
slow_query_log = 1
log_timestamps = SYSTEM
slow_query_log_file = /var/lib/mysql/slow.log
log-error = /var/lib/mysql/error.log
long_query_time = 0.1
log_queries_not_using_indexes =1
log_throttle_queries_not_using_indexes = 60
min_examined_row_limit = 100
log_slow_admin_statements = 1
log_slow_slave_statements = 1
server-id = 3306
log-bin = /var/lib/mysql/mybinlog
sync_binlog = 1
binlog_cache_size = 4M
max_binlog_cache_size = 2G
max_binlog_size = 1G

#注意:MySQL 8.0开始,binlog_expire_logs_seconds选项也存在的话,会忽略expire_logs_days选项
#expire_logs_days = 7

master_info_repository = TABLE
relay_log_info_repository = TABLE
gtid_mode = on
enforce_gtid_consistency = 1
log_slave_updates
slave-rows-search-algorithms = 'INDEX_SCAN,HASH_SCAN'
binlog_format = row
binlog_checksum = 1
relay_log_recovery = 1
relay-log-purge = 1
key_buffer_size = 32M
read_buffer_size = 8M
read_rnd_buffer_size = 4M
bulk_insert_buffer_size = 64M
myisam_sort_buffer_size = 128M
myisam_max_sort_file_size = 10G
myisam_repair_threads = 1
lock_wait_timeout = 3600
explicit_defaults_for_timestamp = 1
innodb_thread_concurrency = 0
innodb_sync_spin_loops = 100
innodb_spin_wait_delay = 30

transaction_isolation = REPEATABLE-READ
#innodb_additional_mem_pool_size = 16M
##########################################NEED SET#################################################
#其他全部使用默认,这个地方的大小设置为内存的70%即可
innodb_buffer_pool_size = 350M
###########################################SET END################################################
innodb_buffer_pool_instances = 4
innodb_buffer_pool_load_at_startup = 1
innodb_buffer_pool_dump_at_shutdown = 1
innodb_data_file_path = ibdata1:1G:autoextend
innodb_flush_log_at_trx_commit = 1
innodb_log_buffer_size = 32M
innodb_log_file_size = 2G
innodb_log_files_in_group = 2
innodb_max_undo_log_size = 4G
innodb_undo_directory = /var/lib/mysql/undolog
innodb_undo_tablespaces = 95

# 根据您的服务器IOPS能力适当调整
# 一般配普通SSD盘的话,可以调整到 10000 - 20000
# 配置高端PCIe SSD卡的话,则可以调整的更高,比如 50000 - 80000
innodb_io_capacity = 4000
innodb_io_capacity_max = 8000
innodb_flush_sync = 0
innodb_flush_neighbors = 0
innodb_write_io_threads = 8
innodb_read_io_threads = 8
innodb_purge_threads = 4
innodb_page_cleaners = 4
innodb_open_files = 65535
innodb_max_dirty_pages_pct = 50
innodb_flush_method = O_DIRECT
innodb_lru_scan_depth = 4000
innodb_checksum_algorithm = crc32
innodb_lock_wait_timeout = 10
innodb_rollback_on_timeout = 1
innodb_print_all_deadlocks = 1
innodb_file_per_table = 1
innodb_online_alter_log_max_size = 4G
innodb_stats_on_metadata = 0

#注意:MySQL 8.0.16开始删除该选项
internal_tmp_disk_storage_engine = InnoDB

# some var for MySQL 5.7
innodb_checksums = 1
#innodb_file_format = Barracuda
#innodb_file_format_max = Barracuda
query_cache_size = 0
query_cache_type = 0
innodb_undo_logs = 128

innodb_status_file = 1
#注意: 开启 innodb_status_output & innodb_status_output_locks 后, 可能会导致log-error文件增长较快
innodb_status_output = 0
innodb_status_output_locks = 0

#performance_schema
performance_schema = 1
performance_schema_instrument = '%memory%=on'
performance_schema_instrument = '%lock%=on'

#innodb monitor
innodb_monitor_enable="module_innodb"
innodb_monitor_enable="module_server"
innodb_monitor_enable="module_dml"
innodb_monitor_enable="module_ddl"
innodb_monitor_enable="module_trx"
innodb_monitor_enable="module_os"
innodb_monitor_enable="module_purge"
innodb_monitor_enable="module_log"
innodb_monitor_enable="module_lock"
innodb_monitor_enable="module_buffer"
innodb_monitor_enable="module_index"
innodb_monitor_enable="module_ibuf_system"
innodb_monitor_enable="module_buffer_page"
innodb_monitor_enable="module_adaptive_hash"

[mysqldump]
quick
max_allowed_packet = 32M

4、cgy_docker/work/components/nginx/nginx.conf

user  nginx;
worker_processes  1;

pid        /var/run/nginx.pid;
error_log  /var/log/nginx/error.log warn;

events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log /dev/null;
    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

5、cgy_docker/work/components/nginx/config/conf.d/localhost.conf

server {
    client_max_body_size 1024m;
    listen       80;
    server_name  localhost;
    charset  utf-8;
    
    location / {
        include /etc/nginx/uwsgi_params;
        #定义uwsgi的socket,即django项目容器的地址和端口
        uwsgi_pass 10.127.2.5:8000;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
    
    #定义项目静态文件目录,注意alias和root的区别
    location /static {
        alias /wwwroot/kcnet/static;
        autoindex on;
    }

    location /media {
        alias /wwwroot/kcnet/media;
        autoindex on;
    }

    error_page 404 /404.html;
            location = /40x.html {
        }

    error_page 500 502 503 504 /50x.html;
        location = /50x.html {
    }
}

6、cgy_docker/work/components/redis/config/redis.conf

#可以根据自己的需要加配置 ,比如requirepass:''

7、cgy_docker/work/components/uwsgi/kcnet/uwsgi.ini

[uwsgi]
uid = www-data
gid = www-data
master = true

;django项目目录路径
chdir     = /wwwroot/kcnet/

;项目的wsgi测试服务器配置文件位置
module = kcnet.wsgi

;定义socket的地址和端口
socket    = 10.127.2.5:8000
processes = 8
threads   = 1
enable-threads = true
chmod-socket = 664
chown-socket = kcnet:www-data
vacuum = true

;定义静态文件
static-map=/static=/wwwroot/kcnet/static
buffer-size  = 65535

8、.env

PROJECT_FOLDER=./work/wwwroot
MYSQL_PASSWORD=root
MYSQL_PORT=3306
REDIS_PORT=6379

9、docker-compose.yml

version: '3'
services:

  ### Django Project-1 container #########################################
  kcnet:
      build:
        #构建django项目kcnet容器的路径
        context: ./build/kcnet
      volumes: #项目数据持久化配置---包括项目、uwsgi配置文件
        - ${PROJECT_FOLDER}/kcnet:/wwwroot/kcnet
        - ./work/components/uwsgi/kcnet/uwsgi.ini:/etc/uwsgi/kcnet/uwsgi.ini
      restart: always  #系统重启后容器自动启动
      privileged: true  #容器启动后是否有系统权限
      networks:   #定义该容器的网桥名称和IP地址
          net-django:
            ipv4_address: 10.127.2.5
      #依赖
      depends_on:
        - redis
        - mysql
      #容器启动后执行的命令,修改容器目录权限、启动uwsgi、迁移数据库、收集静态
      command:
        - /bin/bash
        - -c
        - |
          cd /wwwroot/kcnet
          python manage.py collectstatic --noinput
          python manage.py migrate
          chmod -R 777 /wwwroot/kcnet
          uwsgi --ini /etc/uwsgi/kcnet/uwsgi.ini

  ### Nginx container #########################################
  nginx: 
    image: nginx  #定义nginx使用的镜像,直接从docker hub上获取
    ports:    #定义nginx开放的web端口 80和8080
      - "80:80"
      - "8080:8080"
    volumes:   #nginx数据持久化配置---包括项目、项目nginx配置文件和nginx日志文件
      - ${PROJECT_FOLDER}/kcnet:/wwwroot/kcnet
      - ./work/components/nginx/config/nginx.conf:/etc/nginx/nginx.conf  #windows需要rw权限才能开启nginx服务
      - ./work/components/nginx/config/conf.d:/etc/nginx/conf.d
      - ./work/components/nginx/log:/var/log/nginx
    restart: always   #系统重启后容器自动启动
    privileged: true  #容器启动后是否有系统权限
    networks:     #定义nginx容器的网桥名称和IP地址
      net-django:
        ipv4_address: 10.127.2.4

  ### mysql container #########################################
  mysql:
      image: mysql:5.7   #定义mysql使用的镜像,直接从docker hub上获取
      ports:   #定义mysql开放的数据库端口 根据.env配置变量获取 ${MYSQL_PORT}端口
        - "${MYSQL_PORT}:3306"  # ${MYSQL_PORT}表示地址映射后的端口,3306表示mysql容器内的端口
      volumes:   #mysql数据持久化配置---包括数据库存储位置、数据库配置文件和数据库日志文件路径
        - ./work/components/mysql/data:/var/lib/mysql
        - ./work/components/mysql/config/my.cnf:/etc/mysql/conf.d/my.cnf
        - ./work/components/mysql/log:/var/log/mysql
      restart: always   #系统重启后容器自动启动
      privileged: true   #容器启动后是否有系统权限
      environment:   
        MYSQL_ROOT_PASSWORD: ${MYSQL_PASSWORD}   #通过系统变量${MYSQL_PASSWORD} 设置mysql镜像定义的变量MYSQL_ROOT_PASSWORD
      networks:    #定义mysql容器的网桥名称和IP地址
        net-django:  
          ipv4_address: 10.127.2.3

  ### redis container #########################################
  redis:
      image: redis   #定义redis使用的镜像,直接从docker hub上获取
      ports:   #定义redis开放的数据库端口 根据.env配置变量获取 ${REDIS_PORT}端口
        - "${REDIS_PORT}:6379"  # ${REDIS_PORT}表示地址映射后的端口,6379表示redis容器内的端口
      volumes:   #redis数据持久化配置---包括存储位置、配置文件
        - ./work/components/redis/data:/data
        - ./work/components/redis/config/redis.conf:/usr/local/etc/redis/redis.conf
      restart: always   #系统重启后容器自动启动
      privileged: true   #容器启动后是否有系统权限
      environment:
        - TZ=Asia/Shanghai   #时区
      networks:    #定义redis容器的网桥名称和IP地址
        net-django:
          ipv4_address: 10.127.2.2
      command: redis-server /usr/local/etc/redis/redis.conf # 启动redis服务

### Add Network Bridge info #########################################
networks:   #定义整个docker-compose编排的容器使用的网桥名称和IP地址网段,注意 x.x.x.1不能使用
  net-django:
    ipam:
      config:
        - subnet: 10.127.2.0/24

ps:

1.访问过程

docker-compose安装与部署djnago+uwsgi+nginx+mysql+redis

2.容器间通讯通过网桥子网

# 查看全部子网
docker network ls
#删除子网
docker network rm 子网名称

  

3.构建、启动、关闭和重启命令(在docker-compose.yml目录下进行)

#构建
docker-compose build
#启动
docker-compose up
#后台启动
docker-compose up -d
#关闭
docker-compose stop
#重启
docker-compose restart
#更多功能:docker-compose --help

4.其他命令

#停止全部容器
docker stop $(docker ps -a | awk '{ print $1}' | tail -n +2)
#删除全部容器
docker rm $(docker ps -a | awk '{ print $1}' | tail -n +2)
#删除全部tag为none镜像
docker images|grep none|awk '{print $3}'|xargs docker rmi
#停止全部已开启的容器
docker ps -a | grep 'Up' | awk '{print $1}'| xargs docker container stop
#删除全部已停止的容器
docker ps -a | grep 'Exited' | awk '{print $1}'| xargs docker container rm

 5.更多容器部署参数daocloud