zoukankan      html  css  js  c++  java
  • Centos6.5升级openssh至7.4版本

    ,备份配置文件,以备升级失败进行回退

    ,下载安装包

    wget http://www.zlib.net/zlib-1.2.11.tar.gz

    wget https://openbsd.mirror.netelligent.ca/pub/OpenBSD/OpenSSH/portable/openssh-7.4p1.tar.gz

    wget https://www.openssl.org/source/openssl-1.0.2m.tar.gz

    ,查看当前系统版本

     

    四,开启telnet连接通道

    yum安装telnet

    yum -y install telnet-server*

    关闭防火墙

    /etc/init.d/iptables stop

    编辑配置文件

     vim /etc/xinetd.d/telnet

    disable值yes改为no

    允许root用户通过telnet登录

    mv /etc/securetty /etc/securetty.old

    启动并设置开机启动

    /etc/init.d/xinetd start

                             

    chkconfig xinetd on

    验证 telnet 127.0.0.1

    ,安装编译工具包

     yum  install gcc pam-devel zlib-devel -y

    ,安装zlib

    解压

    tar -xf zlib-1.2.11.tar.gz

    进入目录

    cd zlib-1.2.11

    编译

    ./configure --prefix=/usr

    make

    卸载

    rpm -e --nodeps zlib

    make install

    共享库文件注册到系统

    echo '/usr/lib' >> /etc/ld.so.conf

    ldconfig

    ,升级openssl

    备份当前openssl

    mv /usr/lib64/openssl/ /usr/lib64/openssl.old

    mv /usr/bin/openssl /usr/bin/openssl.old

    mv /etc/pki/ca-trust/extracted/openssl /etc/pki/ca-trust/extracted/openssl.old

    如下两个库文件必须先备份,因系统内部分工具(如yum、wget等)依赖此库,而新版OpenSSL不包含这两个库

    cp /usr/lib64/libcrypto.so.10 /usr/lib64/libcrypto.so.10.old

    cp /usr/lib64/libssl.so.10 /usr/lib64/libssl.so.10.old

    卸载当前openssl

    rpm -qa |grep openssl|xargs -i rpm -e --nodeps {}

    安装openssl

    tar -xf openssl-1.0.2m.tar.gz

    cd openssl-1.0.2m

    ./config --prefix=/usr/local/ssl --openssldir=/etc/ssl --shared zlib

    make

    make test

    make install

    ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl

    ln -s /usr/local/ssl/include/openssl /usr/include/openssl

    echo "/usr/local/ssl/lib" >> /etc/ld.so.conf

    ldconfig -v

    验证

    openssl version

     

    PS:必须加上--shared,否则编译时会因找不到新安装的openssl的类库而报错

    恢复共享库

    mv  /usr/lib64/libcrypto.so.10.old  /usr/lib64/libcrypto.so.10

    mv  /usr/lib64/libssl.so.10.old  /usr/lib64/libssl.so.10

    ,升级openssh

    备份当前openssh

    mv /etc/ssh /etc/ssh.old

    卸载

    rpm -qa |grep openssh|xargs -i rpm -e --nodeps {}

    openssh安装前环境配置

    install  -v -m700 -d /var/lib/sshd

    chown  -v root:sys /var/lib/sshd

    groupadd -g 51 sshd

    useradd  -c 'sshd PrivSep' -d /var/lib/sshd -g sshd -s /bin/false -u 51 sshd

    源码安装

    tar -xf openssh-7.4p1.tar.gz

    cd openssh-7.4p1

    ./configure --prefix=/usr  --sysconfdir=/etc/ssh  --with-md5-passwords  --with-pam  --with-zlib --with-ssl-dir=/usr/local/ssl --with-privsep-path=/var/lib/sshd

    make && make install

    安装后环境配置

    install -v -m755    contrib/ssh-copy-id /usr/bi

    install -v -m644    contrib/ssh-copy-id.1 /usr/share/man/man1

    install -v -m755 -d /usr/share/doc/openssh-7.4p1

    install -v -m644    INSTALL LICENCE OVERVIEW README* /usr/share/doc/openssh-7.4p1

    验证是否安装成功

     

    启动openssh服务

    echo 'X11Forwarding yes' >> /etc/ssh/sshd_config

    允许root直接登录

    echo "PermitRootLogin yes" >> /etc/ssh/sshd_config

    拷贝启动文件设置chkconfig

    cp -p contrib/redhat/sshd.init /etc/init.d/sshd

    chmod +x /etc/init.d/sshd

    chkconfig  --add  sshd

    chkconfig  sshd  on

    重启sshd需要通过telnet才能登录启动sshd

    /etc/init.d/sshd restart

    如果需要还原原来的ssh配置(如不需要则不进行一下操作)

    rm -rf /etc/ssh

    mv /etc/ssh.old /etc/ssh

     恢复登录

    mv  /etc/securetty.old /etc/securetty

    验证 openssh已经升级为更加安全的高版本

     

     PS:如果xshell登录出现

    设置以下即可解决

    参考:https://www.cnblogs.com/share100/p/6862635.html

      http://www.cnblogs.com/ldybyz/p/6699779.html

  • 相关阅读:
    Mybatis 的 xml 文件语法错误,启动项目时控制台一直循环解析但是不打印错误
    在一个由 'L' , 'R' 和 'X' 三个字符组成的字符串(例如"RXXLRXRXL")中进行移动操作。一次移动操作指用一个"LX"替换一个"XL",或者用一个"XR"替换一个"RX"。现给定起始字符串start和结束字符串end,请编写代码,当且仅当存在一系列移动操作使得start可以转换成end时, 返回True。
    【Important】数据库索引原理
    服务化的演变和负载均衡
    【问题集】redis.clients.jedis.exceptions.JedisDataException: ERR value is not an integer or out of range
    【Spring】Spring中用到的设计模式
    【设计模式】责任链模式
    【!Important】Zookeeper用来做什么的,有几种类型的节点
    【!Important】如何保证线程执行的先后顺序
    【!Important】Java线程死锁查看分析方法
  • 原文地址:https://www.cnblogs.com/minseo/p/7879653.html
Copyright © 2011-2022 走看看