• ECS太贵,如何家里机器上的网站发布到公网?


    实现部署需要的环境如下:

    1. 家里机器(win10)通过路由nat上网,没有可用的公网IP,简称机器A1
    2. 配置内网机器通过私钥登陆访问香港地区的ECS,例如win10机器上安装hyper-v虚拟机,虚拟出一台linux主机,上面部署了nginx服务,端口是8080,简称机器A2
    3. 申请一个阿里云非大陆地区的ECS(CentOS7.4),例如一个香港地区的ECS,带有公网IP,假设该机器的ssh端口是1234,主要是香港地区可以不用备案,简称机器B
    4. 申请一个公网域名,指向香港地区的ECS的公网IP
    5. 可以使用autossh或ssh来实现

    一、把A1机器,win10操作系统的远程桌面功能发布到公网,这样就可以在公司访问你家里的机器了

    • 在A1机器上执行:
      实际使用时,可以使用如下的具有断线重连功能的脚本,保存为autossh.bat即可
    @echo off
    echo ******
    :LOOP
    echo [%date% %time%] ssh is running...
    ssh -NR 33890:localhost:3389 root@【B服务器IP】 -p 1234
    timeout 60 > NUL
    goto LOOP
    echo [%date% %time%] remote ssh connection exited ...
    

    ssh相关使用方法说明如下:

    ssh -fCNR [B机器IP或省略]:[B机器端口]:[A机器的IP]:[A机器端口] [登陆B机器的用户名@B服务器IP] -p [B机器自定义的ssh端口]
    
    win10企业版自带ssh,可以在cmd中运行`ssh-keygen -t rsa`生成私钥目录,一般是"C:Users【当前登陆用户】.ssh",把私钥放入这个目录即可
    
    • 在B机器上执行:
      需要检查B机器的sshd_config的下面三项配置
    cat /etc/ssh/sshd_config
    GatewayPorts yes
    ClientAliveInterval 60
    ClientAliveCountMax 3
    

    最后通过访问B机器的33890端口就可以访问到A1机器的3389端口

    二、把A2机器,CentOS7.4操作系统上的nginx服务发布到公网,这样大家就可以在公网访问你的个人网站了

    • 在A2机器上执行:
    yum -y install autossh
    autossh -M 5555 -fCNR *:8080:localhost:80 root@【B服务器IP】 -p 1234
    

    autossh相关使用方法说明如下:

    autossh -M [自定义的监控端口] -fCNR [B机器IP或省略]:[B机器端口]:[A机器的IP]:[A机器端口] [登陆B机器的用户名@服务器IP] -p [B机器自定义的ssh端口]
    
    • 在B机器上执行:
      需要检查B机器的sshd_config的下面三项配置
    cat /etc/ssh/sshd_config
    GatewayPorts yes
    ClientAliveInterval 60
    ClientAliveCountMax 3
    

    最后通过访问B机器的8080端口就可以访问到A2机器的80端口

    TIPS:部署中使用的ssh和autossh的相关参数的说明

    介绍一下使用到的ssh参数,autossh也有一下命令,只是autossh有断线自动重连功能
    反向代理:ssh -fCNR
    正向代理:ssh -fCNL
    
    -f 后台执行ssh指令
    -C 允许压缩数据
    -N 不执行远程指令
    -R 将远程主机(服务器)的某个端口转发到本地端指定机器的指定端口
    -L 将本地机(客户机)的某个端口转发到远端指定机器的指定端口
    -p 指定远程主机的端口
    

    参考:https://www.cnblogs.com/kwongtai/p/6903420.html

    大漠孤烟直 长河落日圆
  • 相关阅读:
    Linux 内核编码风格
    三种批量插入数据的方法
    一次清除SQL SERVER错误日志的体会!
    打开潘多拉的魔盒——软件设计过程(1)——序
    bloom特效
    wcf基础知识之端口共享 portSharing
    高质量代码(一)
    Luence使用IKAnalyzer分词实例 及 IKAnalyzer扩展词库
    通过什么来衡量C# Socket服务的效能
    iOS开发进阶之静态链接库
  • 原文地址:https://www.cnblogs.com/yjb007/p/9669134.html
Copyright © 2020-2023  润新知