如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?
来源:stackoverflow
时间:2024-02-29 11:06:29 390浏览 收藏
编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?》,文章讲解的知识点主要包括,如果你对Golang方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。
我正在尝试使用 exec.command().output() 执行第 3 方工具 (steamcmd) 来下载我运行的服务器的更新。当我通过 powershell 正常运行命令时,一切运行正常。
我运行的示例命令:
c:\steamcmd\steamcmd.exe +force_install_dir "c:\gameserver" +login mallachar +app_update 233780
当我检查应用程序的日志时,它工作正常。
[2022-01-05 23:13:23] 日志会话开始 [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:0] ) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:13:23] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:879488788] ) [2022-01-05 23:13:23] [0,0] setsteamid( [u:1:879488788] ) [2022-01-05 23:13:23] [0,0] 服务器说 50% 的连接应该是 websocket,我们滚动了 41 - 默认使用 websocket。
但是,当我通过 golang 运行它时,它不起作用
import ( "fmt" "os/exec" "strings" ) const armA3ServerID string = "+app_update 233780" func steamSession(configData Server, steamCMDUser string, steamCMDPass string) { var steamCMDCommand strings.Builder steamCMDCommand.WriteString("+force_install_dir \"" + configData.Arma3path + "\" ") steamCMDCommand.WriteString("+login " + steamCMDUser + " " + steamCMDPass + " ") steamCMDCommand.WriteString(armA3ServerID) steamCMDCommand.WriteString(" +quit") out, err := exec.Command(configData.Steamcmdpath+"steamcmd.exe", steamCMDCommand.String()).Output() if err != nil { fmt.Printf("Error Is", err) } fmt.Printf("%s\n", string(out)) }
由于网络问题,命令挂起,我得到此日志输出
[2022-01-05 23:35:59] 日志会话开始 [2022-01-05 23:35:59] [0,0] setsteamid( [u:1:0] ) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 看到设备启动 (192.168.1.254) [2022-01-05 23:35:59] ccminterface::onnetworkdevicestatechange -- 开始连接到 steam [2022-01-05 23:35:59] ipv6 http 连接测试 (ipv6check-http.steamcontent.com / 0.0.0.0:80 (0.0.0.0:80)) - 超时 [2022-01-05 23:35:59] ipv6 udp 连接测试 (ipv6check-udp.steamcontent.com) - 失败,未解析地址
当我终止运行的 steamcmd 后台实例时,我的 golang 程序打印出输出,显示它确实尝试执行,但只是挂在连接部分。
据我所知,当我使用 exec.command 时,我用它启动的服务似乎没有互联网/套接字访问权限?我尝试以管理员身份运行,但似乎没有解决任何问题。不确定是否可能缺少一个步骤或需要更改标志。
因此命令确实运行,后端应用程序运行,但无法解析地址/建立连接。所以看来我的命令本身不是问题,而是 golang exec.command 的问题?
正确答案
您正在向命令传递一个参数,即所有参数的串联。试试这个:
out, err := exec.Command( configData.Steamcmdpath+"steamcmd.exe", "+force_install_dir", configData.Arma3path, "+login ",steamCMDUser,steamCMDPass, "+app_update", "233780", "+quit", ).Output()
今天关于《如何在Windows上使用Golang exec.Command阻止服务的套接字和网络访问?》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习