一款代码部署、应用部署、计划任务、设备资产管理平台。
开源协议:GNU General Public License v2
开源声明:欢迎大家star或者fork我的开源项目,如果大家在自己的项目里面需要引用该项目代码,请在项目里面申明协议和版权信息。
开发语言与框架:
- 编程语言:Python2.7 + HTML + JScripts
- 前端Web框架:Bootstrap
- 后端Web框架:Django
- 后端Task框架:Celery + Redis
OpsManage环境要求
- 编程语言:Python 2.7
- 操作系统:CentOS 6+
- Ansible版本:2.0 +
- 部署平台及节点服务器:Rsync 3+
- MySQL版本:5.1-5.6 #如果用5.7请查看
安装环境配置
一、安装Python
yum install zlib zlib-devel readline-devel sqlite-devel bzip2-devel openssl-devel gdbm-devel libdbi-devel ncurses-libs kernel-devel libxslt-devel libffi-devel python-devel zlib-devel sshpass gcc git -y# yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm# yum install Percona-Server-server-56 Percona-Server-devel-56 -y
wget http://mirrors.sohu.com/python/2.7.12/Python-2.7.12.tgz #CentOS 7不用安装python2.7
tar -xzvf Python-2.7.12.tgz
cd Python-2.7.12
./configure
make all
make install
make clean
make distclean
mv /usr/bin/python /usr/bin/python2.6.6
ln -s /usr/local/bin/python2.7 /usr/bin/python
vi /usr/bin/yum
将文件头部的 #!/usr/bin/python
改成 #!/usr/bin/python2.6.6
二、安装easy_install
# wget --no-check-certificate https://pypi.python.org/packages/f7/94/eee867605a99ac113c4108534ad7c292ed48bf1d06dfe7b63daa51e49987/setuptools-28.0.0.tar.gz#md5=9b23df90e1510c7353a5cf07873dcd22
# tar -xzvf setuptools-28.0.0.tar.gz
# cd setuptools-28.0.0 # python setup.py install
三、安装pip
# wget --no-check-certificate https://github.com/pypa/pip/archive/1.5.5.tar.gz -O pip-1.5.5.tar.gz
tar -xzvf pip-1.5.5.tar.gz
# cd pip-1.5.5/
python setup.py install
pip install -U pip
四、安装模块
# cd /mnt/# git clone https://github.com/welliamcao/OpsManage.git# cd /mnt/OpsManage/ # pip install -r requirements.txt #注意,如果出现错误不要跳过,请根据错误信息尝试解决 # easy_install paramiko==2.4.1
五、安装Redis
# wget http://download.redis.io/releases/redis-3.2.8.tar.gz# tar -xzvf redis-3.2.8.tar.gz# cd redis-3.2.8 # make # make install # vim redis.conf
修改以下配置,不要设置密码
daemonize yesloglevel warninglogfile "/var/log/redis.log" bind 你的服务器ip地址 例如: bind 127.0.0.1 192.168.88.201
# cd ../# mv redis-3.2.8 /usr/local/redis# /usr/local/redis/src/redis-server /usr/local/redis/redis.conf
六、安装MySQL
# vim /etc/my.cnf[mysqld]character_set_server = utf8 添加以上字段 # /etc/init.d/mysqld restart #centos 6 # systemctl start mysql.service #centos 7 # mysql -uroot -p #初始密码为空,直接回车就行 mysql> create database opsmanage DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; mysql> grant all privileges on opsmanage.* to root@'%' identified by 'password'; mysql>\q
七、配置OpsManage
# cd /mnt/OpsManage/OpsManage# vim settings.pyBROKER_URL = redis://192.168.1.233:6379/3 #修改成自己的配置 REDSI_KWARGS_LPUSH = {"host":'192.168.1.233','port':6379,'db':3} #修改成自己的配置 DATABASES = { 'default': { 'ENGINE':'django.db.backends.mysql', 'NAME':'opsmanage', 'USER':'root', #修改成自己的配置 'PASSWORD':'welliam', #修改成自己的配置 'HOST':'192.168.1.233', #修改成自己的配置 'PORT': 3306 # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ["/mnt/OpsManage/OpsManage/static/",'/mnt/OpsManage/OpsManage/templates/'], #修改成自己的配置 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ] STATICFILES_DIRS = ( '/mnt/OpsManage/OpsManage/static/', #修改成自己的配置 )
八、生成数据表与管理员账户
# cd /mnt/OpsManage/# python manage.py makemigrations OpsManage# python manage.py makemigrations wiki # python manage.py makemigrations orders # python manage.py makemigrations filemanage # python manage.py migrate # python manage.py createsuperuser
九、启动部署平台
# cd /mnt/OpsManage/# python manage.py runserver 0.0.0.0:8000 #请继续完成下面的配置Celery步骤
十、配置证书认证
# ssh-keygen -t rsa# ssh-copy-id -i ~/.ssh/id_rsa.pub root@ipaddress
十一、配置Celery异步任务系统
# echo_supervisord_conf > /etc/supervisord.conf# export PYTHONOPTIMIZE=1# vim /etc/supervisord.conf 最后添加,/var/log/celery-*.log这些是日志文件,如果有错误请注意查看 [program:celery-worker-default] command=/usr/bin/python manage.py celery worker --loglevel=info -E -Q default directory=/mnt/OpsManage stdout_logfile=/var/log/celery-worker-default.log autostart=true autorestart=true redirect_stderr=true stopsignal=QUIT numprocs=1 [program:celery-worker-ansible] command=/usr/bin/python manage.py celery worker --loglevel=info -E -Q ansible directory=/mnt/OpsManage stdout_logfile=/var/log/celery-worker-ansible.log autostart=true autorestart=true redirect_stderr=true stopsignal=QUIT numprocs=1 [program:celery-beat] command=/usr/bin/python manage.py celery beat directory=/mnt/OpsManage stdout_logfile=/var/log/celery-beat.log autostart=true autorestart=true redirect_stderr=true stopsignal=QUIT numprocs=1 [program:celery-cam] command=/usr/bin/python manage.py celerycam directory=/mnt/OpsManage stdout_logfile=/var/log/celery-celerycam.log autostart=true autorestart=true redirect_stderr=true stopsignal=QUIT numprocs=1 启动celery # /usr/local/bin/supervisord -c /etc/supervisord.conf # supervisorctl status #要检查是否都是running状态,uptime是不是递增
十二、SQL审核
自行安装Inception与SQLadvisor,SQLadvisor可执行文件请放在OpsManage服务器/usr/bin/sqladvisor路径