文章目录
购买云服务器
可以按照自己情况买,新用户有优惠的,然后有些平台完成学生认证也是有优惠的
本人选购的是轻量应用服务器2核2G4M的,装的Ubuntu 20.04LTS,Linux系统


重置终端密码,配置防火墙,开启SSH远程登录
腾讯云默认用户名为Ubuntu,首次购买后需要重置密码才可通过用户密码登录终端
腾讯云的ssh端口是自动开启的,阿里云端口配置记得是叫安全组

远程连接服务器,设置root密码
ssh ubuntu@公网119.91.237.127 #ubuntu是用户名,后面接自己云服务器的公网IP
sudo passwd root #设置root用户密码
#输入密码
#再次输入
su #root登录


修改ssh配置文件,开启root远程登录
腾讯云默认root账户不能远程登录,需要修改ssh配置文件
sudo vim /etc/ssh/sshd_config #配置ssh的配置文件
/Per #输入斜杠查找指定字符串
将PermitRootLogin那行取消注释,并将后面改为yes
按下ESC,输入wq保存并退出
systemctl restart sshd #重启ssh服务器就可以用root登录了

测试root远程登录
ssh @root"公网IP"

emqx开源版 下载安装
这里根据自己云服务器配置来安装吧
我选择的是版本是 4.2.14 系统是 Ubuntu 20.04
点Download就跳转到下面的界面了,复制三行代码在云端运行就下载好了
wget https://www.emqx.com/en/downloads/broker/4.2.14/emqx-ubuntu20.04-4.2.14-x86_64.deb #下载
ls #查看是否把压缩包下载下来
sudo apt install ./emqx-ubuntu20.04-4.2.14-x86_64.deb #安装
ls /etc/emqx #看看emqx目录下都有啥,如果没有报错就说明已经安装好了
sudo systemctl start emqx #启动emqx服务器



配置云服务器防火墙(阿里云的叫安全组),将emqx的端口都打开
| 端口 | 说明 |
|---|---|
| 1883 | MQTT/TCP 协议端口,一般用于客户端端口 |
| 11883 | MQTT/TCP 协议内部端口,仅用于本机客户端连接 |
| 8883 | MQTT/SSL 协议端口 |
| 8083 | MQTT/WX 协议端口 |
| 8084 | MQTT/WSS 协议端口 |
| 18083 | EMQX后台管理端口 |

重启emqx服务器
emqx restart
登录emqx后台管理界面
浏览器输入:云服务器公网IP:18083 #后面的18083即为端口号,emqx服务器与mqtt协议具体的端口号与对应功能请看云防火墙配置时候的端口功能说明表格
默认用户:admin
默认密码:public
登录后可自行设置风格

到这里emqx服务器就搭建好了!
同时我们就可以实现硬件与服务器的数据交互了。
可以在WebSocKet处测试连接,以及模仿订阅、发布等
如果想修改默认的登录密码可执行以下命令
cd /bin
emqx_ctl admins passwd admin 新密码
具体实现硬件与服务器的数据交互可以参考项目复盘系列之硬件篇—学会白嫖 #待发布
有兴趣的话,可以用mqtt.fx来模拟客服端连接,来接收和发布消息
mqtt.fx.rar 提取码:pfcu
具体操作如下(不需测试的可直接跳过去看域名备案和服务器的证书部署啦)
配置mqtt.fx的客户端基本信息
如下图;而后点击Connect连接,在Dashboard客户端查看是否连接成功



测试发布
MQTT协议是通过订阅发布来进行数据交互的。具体规则请自行查阅
mqtt.fx端发布主题名为:Topic
WebSocket订阅主题名为:Topic
测试数据:aaa

测试订阅
mqtt.fx端订阅主题名为:Topic/1
WebSocket订阅主题名为:Topic/1
数据:{ “msg”: “Hello, World!” }

购买域名可以到腾讯、阿里、华为云等搜域名注册根据指示一步步做即可
域名注册现在需要先实名认证,大概审核需要十几分钟



进入域名控制台域名解析
解析就是将本域名指向指定的IP地址,是一种映射关系
记录值就是填写我们云服务器的公网IP


解析记录添加成功后,就可以用域名来访问emqx啦!如下

虽然刚刚部署完时候我们可以正常通过域名访问我们的emqx服务器,但是再过些时间就访问不了了,如出现如下画面
备案也麻烦,还要工信部审核,快的话几天,最长不超过20天 查看各个省份备案时间。
备案虽麻烦,但是也是为了大家的共同的网络使用环境着想,多一分体谅就多一分幸福。

备案提交后腾讯云工作人员会打电话审核真实身份。
腾讯云审核后工信部过几分钟就会发送短信核验,请根据短信提示进行核验。(湖南是这样的)但是短信核验后好像并不会马上通过,因为在4天前有一个已经核验完了现在还没通过,具体时间请参考
所以请耐心等待




为什么要申请证书?
因为有些平台通信是必须要HTTPS协议的,比如微信小程序。
进入腾讯云证书控制台申请免费SSL证书


回到购买域名的平台添加一条解析记录,注意解析类型

添加解析记录后等待十几分钟证书就会下发了。

下载证书
我这里下载Nginx(为后续程序上线做准备)以及其它(部署emq需要)

ssl证书说明
| 后缀 | 说明 |
|---|---|
| 域名_bundle.crt | CA证书文件 |
| 域名.csr | csr文件时证书签名请求文件,在创建证书时使用,因此配置SSL服务时不需要关心此文件 |
| 域名.key | 我们证书的私钥文件,以base64和格式分隔符加密 |
| .pem | 证书的base64加密文件,即就是证书 |
远程连接云服务器
具体配置实现在第一节,购买云服务器实现远程登录
ssh root@云服务器公网IP

然后咱进入emqx文件下的certs目录下创建ssl目录(这一步可省略)
cd /etc/emqx/certs #路径不一定一样,具体看自己的emqx在哪
mkdir ssl #创建目录ssl

打开本地终端WIN+R 输入cmd,进入下载证书的目录
cd 路径
dir #查看当前目录下的文件

使用scp命令,将证书与密匙文件传到云服务器的ssl目录下
scp ddup.fun.key root@119.91.237.127:/etc/emqx/certs/ssl
scp 文件名 服务器用户名@服务器公网IP:指定存储目录
#注意不要忘掉冒号了

上传后我们可以查看已经成功了

配置emqx.conf文件
需要修改ssl的三个地方
如果也想修改wss就再修改三个地方
用到的vim编辑文件操作
斜杠搜索指定字符串
i 插入
wq保存退出
ESC键 退出当前的操作
cd /etc/emqx #进入emqx目录,路径不一定一样的喔
ls #查看当前目录下的文件
vim emqx.conf #编辑emqx.conf
/listener.ssl.external.keyfile #搜索该字符串位置
#在后面更改为自己的对应ssl证书存储路径(可以到证书目录下输入pwd打印当前的绝对路径)
#剩下两个文件同上
#然后同样步骤再修改wss的三个文件路径
#修改完成后按下ESC,输入:wq保存并退出
emqx restart #最后重启emqx服务器即可
#注:需要用域名来访问才支持ssl与wss,因为证书是绑定到域名的,所以到备案成功后才能支持ssl和wss连接。
成功案例

斜杠搜索

修改ssl

修改wss


我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除
Unity自动旋转动画1.开门需要门把手先动,门再动2.关门需要门先动,门把手再动3.中途播放过程中不可以再次进行操作觉得太复杂?查看我的文章开关门简易进阶版效果:如果这个门可以直接打开的话,就不需要放置"门把手"如果门把手还有钥匙需要旋转,那就可以把钥匙放在门把手的"门把手",理论上是可以无限套娃的可调整参数有:角度,反向,轴向,速度运行时点击Test进行测试自己写的代码比较垃圾,命名与结构比较拉,高手轻点喷,新手有类似的需求可以拿去做参考上代码usingSystem.Collections;usingSystem.Collections.Generic;usingUnityEngine;u
require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame
我有一个使用PDFKit呈现网页的pdf版本的Rails应用程序。我使用Thin作为开发服务器。问题是当我处于开发模式时。当我使用“bundleexecrailss”启动我的服务器并尝试呈现任何PDF时,整个过程会陷入僵局,因为当您呈现PDF时,会向服务器请求一些额外的资源,如图像和css,看起来只有一个线程.如何配置Rails开发服务器以运行多个工作线程?非常感谢。 最佳答案 我找到的最简单的解决方案是unicorn.geminstallunicorn创建一个unicorn.conf:worker_processes3然后使用它:
我将以下代码放在一起用于一个简单的RubyTFTP服务器。它工作正常,因为它监听端口69并且我的TFTP客户端连接到它,我能够将数据包写入test.txt,但我不只是写入数据包,我希望能够从我的客户端通过TFTP传输文件到/temp目录。预先感谢您的帮助!require'socket.so'classTFTPServerdefinitialize(port)@port=portenddefstart@socket=UDPSocket.new@socket.bind('',@port)whiletruepacket=@socket.recvfrom(1024)putspacketFile
在previousquestion中我想出了如何在多个服务器上启动经过密码验证的sshsession来运行单个命令。现在我需要能够执行“sudo”命令。问题是,net-ssh-multi没有分配sudo需要运行的伪终端(pty),导致以下错误:[127.0.0.1:stderr]sudo:sorry,youmusthaveattytorunsudo根据documentation,可以通过调用channel对象的方法来分配伪终端,但是,以下代码不起作用:它会生成上面的“notty”错误:require'net/ssh'require'net/ssh/multi'Net::SSH::Mul
我正在尝试在ruby脚本中连接到服务器https://www.xpiron.com/schedule。但是,当我尝试连接时:require'open-uri'doc=open('https://www.xpiron.com/schedule')我收到以下错误消息:OpenSSL::SSL::SSLError:SSL_connectreturned=1errno=0state=SSLv2/v3readserverhelloA:sslv3alertunexpectedmessagefrom/usr/local/lib/ruby/1.9.1/net/http.rb:678:in`conn