CMDB项目多容器部署过程

准备四个容器

1.redis
2.rabbitmq
3.mydql5.7
4.centos7
5.nginx

先再docker 中创建一个自定义网络

docker network create  网络名

本次创建网络名称为jumpserver-test

docker network create jumpserver-test

启动一个centos系统的容器
先将自己的环境写入到一个txt文件当中
从项目中的 requirments.txt 安装项目的依赖环境包
可以通过 pip3 freeze > requirements.txt 将在本地(开发环境)的虚拟环境下安装的包的信息导出来。
再将自己的项目打包scp传入进去或者从gitliab克隆到容器当中
进入容器当中进入到项目目录下
先部署环境

pip3 install -r requirements.txt

启动容器

docker run -itd --name cmdb-server -p 8080:80 -p 8000:22 --network jumpserver centos7  
docker run -d --name redis-cmdb  --network jumpserver-test redis
docker run -d --name rabbitmq-cmdb  --network jumpserver-test rabbitmq
docker run -d --name mysql57-cmdb  --network jumpserver-test mysql5.7

进入mysql容器当中创建数据库并且创建授权用户

创建数据库并修改字符集
create database 数据库名 CHARACTER SET utf8 COLLATE utf8_general_ci;

grant all on  `cmdb.*`  to  用户@用户ip  identified by '密码'

完成后退出数据库 并测试该用户能否登录

进入项目容器当中

有虚拟环境的话

virtualenvwrapper 部署项目的虚拟环境

安装

pip3 install virtualenvwrapper

配置环境变量

为单个用户添加环境变量信息
编辑用户家目录下的.bashrc 文件

# 设置虚拟环境使用的 python 解释器
export VIRTUALENVWRAPPER_PYTHON=/usr/local/bin/python3

# 设置创建虚拟环境放置的目录
export WORKON_HOME=$HOME/.virtualenv

# 虚拟环境的初始化脚本
source /usr/local/bin/virtualenvwrapper.sh

使其生效

source  ~/.bashrc

为项目新建虚拟环境

mkvirtualenv cmdb

进入虚拟环境

workon cmdb

处理Django项目的静态文件

1.首先在Django 项目的setting 文件中添加如下内容:

STATIC_ROOT = os.path.join(BASE_DIR,"allstatic")

2.在项目的主目录下(manage.py同级)执行如下命令
有虚拟环境的先切换到 虚拟环境下在执行

python3 manage.py collectstatic

执行完这个命令,Django 会搜集项目中所有的静态文件,并将其拷贝到 STATIC_ROOT 指定的目录下。

3.再在项目的配置文件settings.py中,注释以下内容并添加

#STATICFILES_DIRS = [ 
#     os.path.join(BASE_DIR, 'static'), 
#]
添加
STATIC_ROOT = os.path.join(BASE_DIR,"allstatic")

处理完毕项目的静态文件之后, 就可以让后面提到的 uwsgi 或者 nginx 中的任何一个很方便的使用了

Uwsgi 处理 socket 连接

安装

pip3 install uwsgi

执行

uwsgi --http :80   --module testdjango.wsgi --static-map  /static=/xiangmu/testdjango/testdjango/allstatic  --master --processes 4

此时在浏览器中输入主机的 IP 和端口进行访问

关于静态文件找不到的问题,可以在Nginx 配置中解决,
也可以用Uwsgi 解决。
执行如下命令即可:

第一种方式

uwsgi --http :8000 \
--chdir /xiangmu/testdjango/testdjango \
--module testdjango.wsgi \
--master --processes 4 \
--static-map /static=/xiangmu/testdjango/testdjango/allstatic   # 映射静态文件

第二种方式
在项目的主目录下的 conf文件夹下创建文件 cmdb_uwsgi.ini并写入

[uwsgi] 
# 切换到工作目录 
chdir = /xiangmu/testdjango/testdjango
socket = cmdb-server:80    #soket在nginx连接的时候需要使用就需要把http注释 
#http = 本机IP:80
#static-map = /static=/xiangmu/testdjango/testdjango/allstatic   
module = testdjango.wsgi 

master = true 
processes = 6 

# clear environment on exit 
vacuum = true 
# 虚拟环境路径,按自己项目的虚拟环境路径填写,不要照抄!!!如果没有虚拟环境就不需要写
 virtualenv = /root/virtualenv/cmdb 
logto = /tmp/cmdb-server.log

启动测试

uwsgi --ini 你的这个ini文件的具体路径/qf_uwsgi.ini

示例:

(cmdb) [root@master SharkAPAMP]# uwsgi --ini conf/qf_uwsgi.ini
[uWSGI] getting INI configuration from conf/qf_uwsgi.ini
[uwsgi-static] added mapping for /static => /cmdb/SharkAPAMP/allstatic

之后在浏览器里访问,看是否可以看到正常的网页

Nginx 代理

可以利用Nginx做反向代理、负载均衡以及处理静态文件。
启动容器 nginx:alpine3.8

docker run -itd --name nginx-server --network jumpserver-test -p 9000:80 nginx:alpine3.8 

配置 Nginx
vi /etc/nginx/conf.d/default.conf

# the upstream component nginx needs to connect to
upstream django {
    # server unix:///path/to/your/mysite/mysite.sock; # for a file socket
    # Django 的地址和端口
    server cmdb-server:80; # for a web port socket (we'll use this first)
}
# configuration of the server

server {
    # nginx 主机的监听端口
    listen      80;
    # nginx 主机的域名
   # server_name 你的ip地址 或者 FQDN ;
    server_name  nginx-server;
    charset     utf-8;

    # max upload size
    client_max_body_size 75M;   # adjust to taste

    # Django 的静态文件
    location /static {
        alias /allstatic; # 指向django的static目录
    }

    # 最后将非静态资源的请求都转发个 Django
    location / {
        uwsgi_pass  django; # django 和 upstream django 对应
        include     uwsgi_params; # the uwsgi_params file you installed
    }
}

保存后重启nginx服务

/usr/sbin/nginx -s reload

进入django容器中将.ini文件中设置的静态文件路径注释掉
在执行命令

uwsgi --ini conf/cmdb-server.ini

执行完成后
在网页上访问nginx映射本机的端口 这里 配置的为9000

网页就能正常访问则配置成功

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容