在vultr安装和使用golang

时间:2022-05-17 00:24:55

1、vultr可以用微信或支付宝充值,方便。好像推荐别人用还能挣美分,懒得弄了,参加了一个充10刀送50刀的活动,感觉实惠(实际用时感觉有点小贵)。

2、注册登录后,控制面板上billing可查看余额。servers中可部署操作系统,我部署了一个最便宜的Centos7(可以部署多个,我部署完查看余额少了1美分)

3、部署的server名最右边有三个点,点击后的菜单中有View Console,是一个运行在浏览器中的Consol。(点开部署的server,可以找到用户名root和密码),登录View Console后进入了远程的centos7系统中了。

4、输入uname -a 无效;   输入:file /bin/ls 有了x86-64字样  ; 输入cat /etc/os-release,有了centos 7的字样

5、输入yum   或wget 或 rpm 或vi (在vi中用  :q  退出)都有,OK!

6、直接 yum install golang 安装成功。 输入go version 查看go版本。输入whereis go 和whereis golang 查看安装位置

7、从本地windows向centos7传文件,看了下xshell 收费。还是用putty  (https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html),安装运行.

安装putty目录中还有个PuTTygen ,首先用它生成(运行后晃动鼠标生成)SSH key   (https://www.vultr.com/docs/how-do-i-generate-ssh-keys/),

然后点save private key,再将public key的全部内容复制server的SSH key中保存。用putty连接后发现还是不能上传下载文件,还要用安装WinSCP或者Filezilla。感觉putty与View Console没区别。突然发现putty目录中有psftp ,运行后按提示open  ,连接成功,可在远程用ls  cd 等命令查看了。

8、在psftp中,运行 get xxx   就将xxx 从远程下载到psftp所在目录中了。将以下代码保存为main.go,并放到psftp目录中

package main

import (
    "fmt"
    "net/http"
)

func main() {
    http.HandleFunc("/", IndexHandler)
    http.ListenAndServe(":9090", nil)
}

func IndexHandler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintln(w, "hello world!!!")
}

执行 put main.go,上传到了远程的/usr/bin/main.go;然后执行go run main.go  不行。

9、用liteide将上面的main.go交叉编译为linux64程序,名为gohttphello。再用psftp上传后,用  chmod +x gohttphello 加上执行权限,

用  ./gohttphello 运行,提示Text file busy    , 先用yum install psmisc 来安装 fuser  ,然后 fuser gohttphello   无效果。重新./gohttphello无效

10、重新用psftp上传   put main.go  ,然后在putty中 go build -o gohello main.go ,再./gohello ,看到程序运行了(我在代码中加一句控制台输出),但通过浏览器远程无法访问。

11、通过View Console执行   firewall-cmd --state ,显示防火墙running  ;用systemctl stop firewalld.service #关闭防火墙,然后http://X.X.X.X(远程IP),终于成功显示出hello world!!!

12、最后:用systemctl start firewalld.service 重启防火墙 .用以下命令开放9090端口

输入 nohup gohello &        使程序在后台运行

用 ps a 查看当前终端下的所有进程信息,包括其他用户的进程。

用kill  -9  PID数字          结束进程

firewall-cmd --get-active-zones (无显示,应该是zone为空)

firewall-cmd --zone=/tcp --permanent  (永久开放9090端口)

firewall-cmd --reload (重启防火墙)

firewall-cmd --query-port=/tcp  (查看端口是否开放)

参考:(一并致谢)

https://www.cnblogs.com/lzxianren/p/5518919.html

https://www.cnblogs.com/nucdy/p/5702330.html

https://www.cnblogs.com/pcyy/p/7568820.html

https://blog.csdn.net/bihailan123/article/details/80067663

https://www.cnblogs.com/litifeng/p/6891330.html

https://blog.csdn.net/iw1210/article/details/16862147

https://blog.csdn.net/Evan_QB/article/details/79811949

https://blog.csdn.net/zx110503/article/details/78787483

https://www.ibm.com/developerworks/cn/linux/l-cn-nohup

https://www.cnblogs.com/liutao1122/p/8268932.html