CentOS 7 建議在一個純凈的 centos7上進行下麵的安裝部署$ setenforce 0 # 臨時關閉,重啟後失效$ systemctl stop firewalld.service # 臨時關閉,重啟後失效# 修改字元集,否則可能報 input/output error的問題,因為日誌里 ...
CentOS 7 建議在一個純凈的 centos7上進行下麵的安裝部署
$ setenforce 0 # 臨時關閉,重啟後失效
$ systemctl stop firewalld.service # 臨時關閉,重啟後失效
# 修改字元集,否則可能報 input/output error的問題,因為日誌里列印了中文
$ localedef -c -f UTF-8 -i zh_CN zh_CN.UTF-8
$ export LC_ALL=zh_CN.UTF-8
$ echo 'LANG="zh_CN.UTF-8"' > /etc/locale.conf
一. 準備 Python3 和 Python 虛擬環境¶
1.1 安裝依賴包
$ yum -y install wget sqlite-devel xz gcc automake zlib-devel openssl-devel epel-release git
1.2 編譯安裝
$ wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tar.xz $ tar xvf Python-3.6.1.tar.xz && cd Python-3.6.1 $ ./configure && make && make install # 這裡必須執行編譯安裝,否則在安裝 Python 庫依賴時會有麻煩...
1.3 建立 Python 虛擬環境
因為 CentOS 6/7 自帶的是 Python2,而 Yum 等工具依賴原來的 Python,為了不擾亂原來的環境我們來使用 Python 虛擬環境
$ cd /opt $ python3 -m venv py3 $ source /opt/py3/bin/activate # 看到下麵的提示符代表成功,以後運行 Jumpserver 都要先運行以上 source 命令,以下所有命令均在該虛擬環境中運行 (py3) [root@localhost py3]
1.4 自動載入 Python 虛擬環境配置
此項僅為懶癌晚期的人員使用,防止運行 Jumpserver 時忘記載入 Python 虛擬環境導致程式無法運行。使用autoenv
$ cd /opt $ git clone git://github.com/kennethreitz/autoenv.git $ echo 'source /opt/autoenv/activate.sh' >> ~/.bashrc $ source ~/.bashrc
二. 安裝 Jumpserver
2.1 下載或 Clone 項目
項目提交較多 git clone 時較大,你可以選擇去 Github 項目頁面直接下載zip包。
$ cd /opt/ $ git clone https://github.com/jumpserver/jumpserver.git && cd jumpserver && git checkout master $ echo "source /opt/py3/bin/activate" > /opt/jumpserver/.env # 進入 jumpserver 目錄時將自動載入 python 虛擬環境
2.2 安裝依賴 RPM 包
$ cd /opt/jumpserver/requirements $ yum -y install $(cat rpm_requirements.txt) # 如果沒有任何報錯請繼續
2.3 安裝 Python 庫依賴
$ pip install -r requirements.txt # 不要指定-i參數,因為鏡像上可能沒有最新的包,如果沒有任何報錯請繼續
這點需要耐心等候,如果報錯退出,請重試
2.4 安裝 Redis, Jumpserver 使用 Redis 做 cache 和 celery broke
$ yum -y install redis $ systemctl enable redis $ systemctl start redis
2.5 安裝 MySQL
用 Mysql 作為資料庫,如果不使用 Mysql 可以跳過本步驟
# centos7 $ yum -y install mariadb mariadb-devel mariadb-server # centos7下安裝的是mariadb $ systemctl enable mariadb $ systemctl start mariadb
2.6 創建資料庫 Jumpserver 並授權
$ mysql > create database jumpserver default charset 'utf8'; > grant all on jumpserver.* to 'jumpserver'@'127.0.0.1' identified by '123456'; > flush privileges;
2.7 修改 Jumpserver 配置文件
$ cd /opt/jumpserver $ cp config_example.py config.py $ vi config.py
註意: 配置文件是 Python 格式,不要用 TAB,而要用空格
"""
jumpserver.config
~~~~~~~~~~~~~~~~~
Jumpserver project setting file
:copyright: (c) 2014-2017 by Jumpserver Team
:license: GPL v2, see LICENSE for more details.
"""
import os
BASE_DIR = os.path.dirname(os.path.abspath(__file__))
class Config:
# Use it to encrypt or decrypt data
# Jumpserver 使用 SECRET_KEY 進行加密,請務必修改以下設置
# SECRET_KEY = os.environ.get('SECRET_KEY') or '2vym+ky!997d5kkcc64mnz06y1mmui3lut#(^wd=%s_qj$1%x'
SECRET_KEY = '請隨意輸入隨機字元串(推薦字元大於等於 50位)'
# Django security setting, if your disable debug model, you should setting that
ALLOWED_HOSTS = ['*']
# DEBUG 模式 True為開啟 False為關閉,預設開啟,生產環境推薦關閉
# 註意:如果設置了DEBUG = False,訪問8080埠頁面會顯示不正常,需要搭建 nginx 代理才可以正常訪問
DEBUG = os.environ.get("DEBUG") or True
# 日誌級別,預設為DEBUG,可調整為INFO, WARNING, ERROR, CRITICAL,預設INFO
LOG_LEVEL = os.environ.get("LOG_LEVEL") or 'WARNING'
LOG_DIR = os.path.join(BASE_DIR, 'logs')
# 使用的資料庫配置,支持sqlite3, mysql, postgres等,預設使用sqlite3
# See https://docs.djangoproject.com/en/1.10/ref/settings/#databases
# 預設使用SQLite3,如果使用其他資料庫請註釋下麵兩行
# DB_ENGINE = 'sqlite3'
# DB_NAME = os.path.join(BASE_DIR, 'data', 'db.sqlite3')
# 如果需要使用mysql或postgres,請取消下麵的註釋並輸入正確的信息,本例使用mysql做演示(mariadb也是mysql)
DB_ENGINE = os.environ.get("DB_ENGINE") or 'mysql'
DB_HOST = os.environ.get("DB_HOST") or '127.0.0.1'
DB_PORT = os.environ.get("DB_PORT") or 3306
DB_USER = os.environ.get("DB_USER") or 'jumpserver'
DB_PASSWORD = os.environ.get("DB_PASSWORD") or 'somepassword'
DB_NAME = os.environ.get("DB_NAME") or 'jumpserver'
# Django 監聽的ip和埠,生產環境推薦把0.0.0.0修改成127.0.0.1,這裡的意思是允許x.x.x.x訪問,127.0.0.1表示僅允許自身訪問
# ./manage.py runserver 127.0.0.1:8080
HTTP_BIND_HOST = '0.0.0.0'
HTTP_LISTEN_PORT = 8080
# Redis 相關設置
REDIS_HOST = os.environ.get("REDIS_HOST") or '127.0.0.1'
REDIS_PORT = os.environ.get("REDIS_PORT") or 6379
REDIS_PASSWORD = os.environ.get("REDIS_PASSWORD") or ''
REDIS_DB_CELERY = os.environ.get('REDIS_DB') or 3
REDIS_DB_CACHE = os.environ.get('REDIS_DB') or 4
def __init__(self):
pass
def __getattr__(self, item):
return None
class DevelopmentConfig(Config):
pass