自动化发布利器-Spug部署篇

写在前面:
开源项目地址:https://github.com/openspug/spug.git
感谢Spug项目人员,请帮忙一起支持下,点star~

工作之余写一下自己的经验,以便后期翻阅,不足之处请留言,我会及时更改。
之前使用过walle 1.0、walle 2.0、syncd等自动化发布,但根据公司业务最后选择了spug,所以还是适合自己的最好。下面简单介绍下在Ubuntu环境中的部署细节(部署篇),以及我们在用的生产环境的案例(案例篇)

一键安装部署

暂不介绍,看官网即可(CentOS或Ubuntu都可用)

Docker部署

暂不介绍,看官网即可(后面闲下来再补吧)
需要注意的是,如果要构建项目,或者 command not found 问题,
建议按照自身需要修改 Dockerfile 重新构建下 docker image,比如安装jdk/yarn/node等依赖项及编译环境

手动部署

  • 环境版本

OS Version:Ubuntu 16.04.6 LTS
Python: 3.6.10
MySQL:5.7
Redis:3.0.6

  • 安装环境
# 安装MySQL
sudo apt-get update
sudo apt-get install mysql-server mysql-client libmysqlclient-dev
sudo mysql -V

# 安装Redis
sudo apt-get update
sudo  apt-get install redis-server
sudo redis-server -v

# 安装git
sudo apt-get remove git-core
sudo add-apt-repository ppa:git-core/ppa
sudo apt update
sudo apt install git
sudo git version

# 安装系统依赖
sudo apt-get update
sudo apt-get install python3-dev python3-venv \
libsasl2-dev libldap2-dev gcc nginx supervisor
---
需要的依赖包暂时记不起还有什么了,之前部署好就没在管,所以如果有安装依赖的问题,可以在下面留言
---
  • 安装Spug
# 拉取 spug 项目
mkdir /data/spug && git clone https://github.com/openspug/spug /data/spug && cd /data/spug
git checkout v2.3.2   # x.x.x 为指定的发行版本,例如 git checkout v2.3.2 , 可前往项目地址查看最新版本

# 下载 spug 前端文件
wget https://github.com/openspug/spug/releases/download/v2.3.2/spug_web_2.3.2.tar.gz
tar xf spug_web_2.3.2.tar.gz -C /data/spug/spug_web/

# 创建虚拟运行环境
cd /data/spug/spug_api
python3 -m venv venv
source venv/bin/activate

# 安装python包
# 安装完后 pip list 下,检查下是否全部安装了
pip install -r requirements.txt -i https://pypi.doubanio.com/simple/
pip install gunicorn mysqlclient -i https://pypi.doubanio.com/simple/
  • 配置Spug
# 创建配置文件
# 在 spug_api/spug/ 目录下创建 overrides.py 文件,
# 启动后端服务后会自动覆盖默认的配置,避免直接修改 settings.py 以便于后期获取新版本。
$ vi spug_api/spug/overrides.py

DEBUG = False
ALLOWED_HOSTS = ['127.0.0.1']

DATABASES = {
    'default': {
        'ATOMIC_REQUESTS': True,
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'spug',             # 替换为自己的数据库名,请预先创建好编码为utf8mb4的数据库
        'USER': 'spug_user',        # 数据库用户名
        'PASSWORD': 'spug_passwd',  # 数据库密码
        'HOST': '127.0.0.1',        # 数据库地址
        'OPTIONS': {
            'charset': 'utf8mb4',
            'sql_mode': 'STRICT_TRANS_TABLES',
            #'unix_socket': '/opt/mysql/mysql.sock' # 如果是本机数据库,且不是默认安装的Mysql,需要指定Mysql的socket文件路径
        }
    }
}
  • 初始化数据库
cd /data/spug/spug_api
python manage.py initdb

#创建默认管理员账号
$ python manage.py useradd -u admin -p spug.dev -s -n 管理员

# -u 用户名
# -p 密码
# -s 超级管理员
# -n 用户昵称
  • 配置启动脚本
# 创建启动脚本
$ vi /etc/supervisord.d/spug.ini

[program:spug-api]
command = bash /data/spug/spug_api/tools/start-api.sh
autostart = true
stdout_logfile = /data/spug/spug_api/logs/api.log
redirect_stderr = true

[program:spug-ws]
command = bash /data/spug/spug_api/tools/start-ws.sh
autostart = true
stdout_logfile = /data/spug/spug_api/logs/ws.log
redirect_stderr = true

[program:spug-worker]
command = bash /data/spug/spug_api/tools/start-worker.sh
autostart = true
stdout_logfile = /data/spug/spug_api/logs/worker.log
redirect_stderr = true

[program:spug-monitor]
command = bash /data/spug/spug_api/tools/start-monitor.sh
autostart = true
stdout_logfile = /data/spug/spug_api/logs/monitor.log
redirect_stderr = true

[program:spug-scheduler]
command = bash /data/spug/spug_api/tools/start-scheduler.sh
autostart = true
stdout_logfile = /data/spug/spug_api/logs/scheduler.log
redirect_stderr = true

---
关于如何改装一下listen address 和 port
$ vim /data/spug/spug_api/tools/start-api.sh
exec gunicorn -b 192.168.1.10:9101 -w 2 --threads 8 --access-logfile - spug.wsgi
$ vim /data/spug/spug_api/tools/start-api.sh
exec daphne -b 192.168.1.10 -p 9102 spug.asgi:application

注:记得Nginx那块也得改下
---

  • 配置Nginx配置文件
$ vi /etc/nginx/conf.d/spug.conf

server {
        listen 80;
        server_name localhost;     # 修改为自定义的访问域名
        root /data/spug/spug_web/build/;
        client_max_body_size 20m;   # 该值会影响文件管理器可上传文件的大小限制,请合理调整

        location ^~ /api/ {
                rewrite ^/api(.*) $1 break;
                proxy_pass http://127.0.0.1:9101; # 如有修改脚本,记得改端口
                proxy_redirect off;
                proxy_set_header X-Real-IP $remote_addr;
        }

        location ^~ /api/ws/ {
                rewrite ^/api(.*) $1 break;
                proxy_pass http://127.0.0.1:9102; # 如有修改脚本,记得改端口
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "Upgrade";
                proxy_set_header X-Real-IP $remote_addr;
        }

        error_page 404 /index.html;
}
  • 更新升级

$ cd spug_api
$ source venv/bin/activate
$ python manage.py update
# 下载 spug 前端文件替换
wget https://github.com/openspug/spug/releases/download/vx.x.x/spug_web_x.x.x.tar.gz
tar xf spug_web_x.x.x.tar.gz -C /data/spug/spug_web/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351