• 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、文件结构

     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.访问过程

    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

  • 相关阅读:
    ssm框架整合入门系列——删除-员工的删除
    ssm框架整合入门系列——修改-员工的修改
    git新建分支并推送至远程仓库库
    想带你去火星看日出
    offsetTop无法获取目标display为none的值
    Vue axios 读取api.github.com展示用户信息
    ssm框架整合入门系列——新增-员工的添加
    课时10:列表:一个打了激素的数组1
    课时9:了不起的分支和循环3
    课时8:了不起的分支和循环2
  • 原文地址:https://www.cnblogs.com/konglingxi/p/12497347.html
Copyright © 2020-2023  润新知