jumpserver for C7-一步一步安装

 

一步一步安装

 

首先确保,没有安装ansible!!!!!!!!!!!!!!!!!

 

 

# 修改字符集,否则可能报 input/output error的问题,因为日志里打印了中文

localectl set-locale LANG=zh_CN.utf8

 

#安装依赖

yum install libffi-devel openssl openssl-devel zlib-devel bzip2-devel ncurses-devel sqlite-devel readline-devel tk-devel expat-devel gdbm-devel db4-devel libpcap-devel xz-devel python-devel

yum install libxml*

 

 

#编译安装python3

wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tar.xz

 

./configure

make

make install

 

 

#建立Python虚拟环境

cd /opt

python3 -m venv py3

source /opt/py3/bin/activate

 

# 看到下面的提示符代表成功,以后运行 Jumpserver 都要先运行以上 source 命令,以下所有命令均在该虚拟环境中运行

(py3) [root@localhost py3]

 

 

vim /root/.bashrc

添加:

source /opt/py3/bin/activate

 

 

 

二. 安装 Jumpserver

 

2.1 下载

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 虚拟环境

 

# 首次进入 jumpserver 文件夹会有提示,按 y 即可

# Are you sure you want to allow this? (y/N) y

 

 

2.2 安装依赖 RPM 包

cd /opt/jumpserver/requirements

yum -y install $(cat rpm_requirements.txt) # 如果没有任何报错请继续

 

 

2.3 安装 Python 库依赖

 

#配置国内python源(pypi)

mkdir -p ~/.pip

cat > ~/.pip/pip.conf << EOF

[global]

timeout=60

index-url=https://pypi.tuna.tsinghua.edu.cn/simple

 

[install]

trusted-host=https://pypi.tuna.tsinghua.edu.cn

EOF

 

 

pip install -r requirements.txt

 

#说明:-i 指定pip下载源地址

pip install -r requirements.txt -i https://pypi.python.org/simple

 

 

 

2.4 安装 Redis, Jumpserver 使用 Redis 做 cache 和 celery broke

yum -y install redis

systemctl enable redis

systemctl start redis

 

 

2.5 安装 MySQL

yum -y install mariadb mariadb-devel mariadb-server

systemctl enable mariadb

systemctl start mariadb

 

 

2.6 创建数据库 Jumpserver 并授权

 

create database jumpserver default charset 'utf8';

grant all on jumpserver.* to 'jumpserver'@'127.0.0.1' identified by 'weakPassword';

flush privileges;

 

 

2.7 修改 Jumpserver 配置文件

 

cd /opt/jumpserver

cp config_example.py config.py

 

vim config.py

"""

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'

 

# 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 'weakPassword'

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

 

 

class TestConfig(Config):

pass

 

 

class ProductionConfig(Config):

pass

 

 

# Default using Config settings, you can write if/else for different env

config = DevelopmentConfig()

 

 

 

2.8 生成数据库表结构和初始化数据

cd /opt/jumpserver/utils

bash make_migrations.sh

 

 

 

2.9 运行 Jumpserver

cd /opt/jumpserver

./jms start all -d

 

# 新版本更新了运行脚本,使用方式./jms start|stop|status|restart all 后台运行请添加 -d 参数

 

 

运行不报错,请浏览器访问 http://10.0.0.61:8080/ 默认账号: admin 密码: admin

页面显示不正常先不用处理,继续往下操作,后面搭建 nginx 代理后即可正常访问,原因是因为 django 无法在非 debug 模式下加载静态资源

 

 

 

三. 安装 SSH Server 和 WebSocket Server: Coco

 

3.1 下载或 Clone 项目

cd /opt

source /opt/py3/bin/activate

git clone https://github.com/jumpserver/coco.git

cd coco

git checkout master

echo "source /opt/py3/bin/activate" > /opt/coco/.env # 进入 coco 目录时将自动载入 python 虚拟环境

 

# 首次进入 coco 文件夹会有提示,按 y 即可

# Are you sure you want to allow this? (y/N) y

 

 

 

3.2 安装依赖

cd /opt/coco/requirements

yum -y install $(cat rpm_requirements.txt)

pip install -r requirements.txt

 

 

 

3.3 修改配置文件并运行

cd /opt/coco

cp conf_example.py conf.py # 如果 coco 与 jumpserver 分开部署,请手动修改 conf.py

 

 

vim conf.py

#!/usr/bin/env python3

# -*- coding: utf-8 -*-

#

 

import os

 

BASE_DIR = os.path.dirname(__file__)

 

 

class Config:

"""

Coco config file, coco also load config from server update setting below

"""

# 项目名称, 会用来向Jumpserver注册, 识别而已, 不能重复

# NAME = "localhost"

NAME = "coco"

 

# Jumpserver项目的url, api请求注册会使用, 如果Jumpserver没有运行在127.0.0.1:8080,请修改此处

# CORE_HOST = os.environ.get("CORE_HOST") or 'http://127.0.0.1:8080'

CORE_HOST = 'http://0.0.0.0:8080'

 

# 启动时绑定的ip, 默认 0.0.0.0

# BIND_HOST = '0.0.0.0'

 

# 监听的SSH端口号, 默认2222

# SSHD_PORT = 2222

 

# 监听的HTTP/WS端口号,默认5000

# HTTPD_PORT = 5000

 

# 项目使用的ACCESS KEY, 默认会注册,并保存到 ACCESS_KEY_STORE中,

# 如果有需求, 可以写到配置文件中, 格式 access_key_id:access_key_secret

# ACCESS_KEY = None

 

# ACCESS KEY 保存的地址, 默认注册后会保存到该文件中

# ACCESS_KEY_STORE = os.path.join(BASE_DIR, 'keys', '.access_key')

 

# 加密密钥

# SECRET_KEY = None

 

# 设置日志级别 ['DEBUG', 'INFO', 'WARN', 'ERROR', 'FATAL', 'CRITICAL']

# LOG_LEVEL = 'INFO'

LOG_LEVEL = 'WARN'

 

# 日志存放的目录

# LOG_DIR = os.path.join(BASE_DIR, 'logs')

 

# Session录像存放目录

# SESSION_DIR = os.path.join(BASE_DIR, 'sessions')

 

# 资产显示排序方式, ['ip', 'hostname']

# ASSET_LIST_SORT_BY = 'ip'

 

# 登录是否支持密码认证

# PASSWORD_AUTH = True

 

# 登录是否支持秘钥认证

# PUBLIC_KEY_AUTH = True

 

# SSH白名单

# ALLOW_SSH_USER = 'all' # ['test', 'test2']

 

# SSH黑名单, 如果用户同时在白名单和黑名单,黑名单优先生效

# BLOCK_SSH_USER = []

 

# 和Jumpserver 保持心跳时间间隔

# HEARTBEAT_INTERVAL = 5

 

# Admin的名字,出问题会提示给用户

# ADMINS = ''

COMMAND_STORAGE = {

"TYPE": "server"

}

REPLAY_STORAGE = {

"TYPE": "server"

}

 

# SSH连接超时时间 (default 15 seconds)

# SSH_TIMEOUT = 15

 

# 语言 = en

LANGUAGE_CODE = 'zh'

 

 

config = Config()

 

 

 

./cocod start -d

 

# 新版本更新了运行脚本,使用方式./cocod start|stop|status|restart 后台运行请添加 -d 参数

 

 

启动成功后去Jumpserver 会话管理-终端管理(http://192.168.244.144:8080/terminal/terminal/)

接受coco的注册

 

 

 

 

四. 安装 Web Terminal 前端: Luna

cd /opt

wget https://github.com/jumpserver/luna/releases/download/1.4.1/luna.tar.gz

tar xf luna.tar.gz

chown -R root:root luna

 

 

 

-----------------------------------------------------------------------------------------------

五. 安装 Windows 支持组件(如果不需要管理 windows 资产,可以直接跳过这一步)

 

因为手动安装 guacamole 组件比较复杂,这里提供打包好的 docker 使用, 启动 guacamole

 

5.1 Docker安装 (仅针对CentOS7,CentOS6安装Docker相对比较复杂)

 

$ yum remove docker-latest-logrotate docker-logrotate docker-selinux dockdocker-engine

$ yum install -y yum-utils device-mapper-persistent-data lvm2

 

 

# 添加docker官方源

$ yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

$ yum makecache fast

$ yum install docker-ce

 

# 国内部分用户可能无法连接docker官网提供的源,这里提供阿里云的镜像节点供测试使用

$ yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

$ rpm --import http://mirrors.aliyun.com/docker-ce/linux/centos/gpg

$ yum makecache fast

$ yum -y install docker-ce

 

$ systemctl start docker

$ systemctl status docker

 

 

 

5.2 启动 Guacamole

 

这里所需要注意的是 guacamole 暴露出来的端口是 8081,若与主机上其他端口冲突请自定义

 

# 注意:这里需要修改下 http://<填写jumpserver的url地址> 例: http://192.168.244.144, 否则会出错, 带宽有限, 下载时间可能有点长

# 不能使用 127.0.0.1 ,可以更换 registry.jumpserver.org/public/guacamole:latest

 

docker run --name jms_guacamole -d \

-p 8081:8080 -v /opt/guacamole/key:/config/guacamole/key \

-e JUMPSERVER_KEY_DIR=/config/guacamole/key \

-e JUMPSERVER_SERVER=http://10.0.0.61 \

jumpserver/guacamole:latest

 

 

启动成功后去Jumpserver 会话管理-终端管理(http://10.0.0.61/terminal/terminal/)接受[Gua]开头的一个注册

 

----------------------------------------------------------------------------------------------------------------

 

 

 

六. 配置 Nginx 整合各组件

 

#配置nginx源

nginx.repo

[nginx]

name=nginx repo

baseurl=http://nginx.org/packages/centos/7/$basearch/

gpgcheck=0

enabled=1

 

#安装nginx

yum install nginx

 

 

vim /etc/nginx/conf.d/jumpserver.conf

server {

listen 80; # 代理端口,以后将通过此端口进行访问,不再通过8080端口

 

client_max_body_size 100m; # 录像上传大小限制

 

location /luna/ {

try_files $uri / /index.html;

alias /opt/luna/; # luna 路径,如果修改安装目录,此处需要修改

}

 

location /media/ {

add_header Content-Encoding gzip;

root /opt/jumpserver/data/; # 录像位置,如果修改安装目录,此处需要修改

}

 

location /static/ {

root /opt/jumpserver/data/; # 静态资源,如果修改安装目录,此处需要修改

}

 

location /socket.io/ {

proxy_pass http://localhost:5000/socket.io/; # 如果coco安装在别的服务器,请填写它的ip

proxy_buffering off;

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection "upgrade";

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

access_log off;

}

 

# location /guacamole/ {

# proxy_pass http://localhost:8081/; # 如果guacamole安装在别的服务器,请填写它的ip

# proxy_buffering off;

# proxy_http_version 1.1;

# proxy_set_header Upgrade $http_upgrade;

# proxy_set_header Connection $http_connection;

# proxy_set_header X-Real-IP $remote_addr;

# proxy_set_header Host $host;

# proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

# access_log off;

# }

 

location / {

proxy_pass http://localhost:8080; # 如果jumpserver安装在别的服务器,请填写它的ip

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

}

}

 

 

启动nginx

systemctl start nginx.service

systemctl enable nginx.service

 

 

 

6.4 开始使用 Jumpserver

 

检查应用是否已经正常运行

 

$ cd /opt/jumpserver

$ ./jms status # 确定jumpserver已经运行,如果没有运行请重新启动jumpserver

 

$ cd /opt/coco

$ ./cocod status # 确定jumpserver已经运行,如果没有运行请重新启动coco

 

 

# 如果安装了 Guacamole

$ docker ps # 检查容器是否已经正常运行,如果没有运行请重新启动Guacamole

 

 

 

 

服务全部启动后,访问 http://10.0.0.61,访问nginx代理的端口,不要再通过8080端口访问

 

默认账号: admin 密码: admin

 

 

如果部署过程中没有接受应用的注册,需要到Jumpserver 会话管理-终端管理 接受 Coco Guacamole 等应用的注册。

 

 

 

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

 

以后启动

 

systemctl status redis.service

systemctl status mariadb.service

systemctl status nginx.service

 

 

启动jumpserver

cd /opt/jumpserver

./jms start all -d

 

 

启动coco

cd /opt/coco

./cocod start -d

 

 

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

 

 

 

测试连接

 

ssh admin@10.0.0.61 2222

sftp admin@10.0.0.61 2222

密码: admin

 

如果能登陆代表部署成功

 

 

 

# sftp默认上传的位置在资产的 /tmp 目录下

# windows拖拽上传的位置在资产的 Guacamole RDP上的 G 目录下

 

 

 

 

##############################################################################################

 

 

#基本设置

http://10.0.0.61

 

 

#终端设置

 

使用密钥认证

 

 

#创建用户(用于登录跳板机)

wuxing

 

 

 

#创建管理用户(Jumpserver使用该用户来 `推送系统用户`、`获取资产硬件信息`等)

此处使用root

 

ssh-keygen -t rsa

cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

chmod 400 ~/.ssh/authorized_keys

 

 

 

 

#创建系统用户(系统用户是 Jumpserver跳转登录资产时使用的用户,可以理解为登录资产用户)

此用户可创建也可不创建

useradd oldboy

echo 123456 |passwd --stdin oldboy

ssh-keygen -t rsa

 

 

 

 

#创建资产

 

 

 

#创建授权规则

 

此步会将系统用户推送到资产

 

 

 

#用户使用资产

 

xshell登录将公钥上传给管理用户

posted @ 2018-10-23 14:03  只许澎湃不许爱  阅读(679)  评论(0编辑  收藏  举报