zoukankan      html  css  js  c++  java
  • 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登录将公钥上传给管理用户

  • 相关阅读:
    云题库错题分析
    数据库相关子查询
    阻止事件冒泡
    21分钟 MySQL 入门教程(转载!!!)
    java接口
    java访问修饰符
    小游戏,快速击键
    个人对Java中多态的一些简单理解
    简述抽象和封装,对你学习Java有一些作用
    Bank,我只是来完成作业的
  • 原文地址:https://www.cnblogs.com/fangdecheng/p/9836287.html
Copyright © 2011-2022 走看看