草庐IT

linux项目开发

全部标签

ruby-on-rails - 基于API的应用程序开发的困惑

传统上,我使用RubyonRails构建应用程序,很少提取服务。我现在正在转向更易于管理和更高效的东西(带API的SOA)。让我感到困惑的是,如果我用Go之类的语言构建API服务器,我究竟会失去什么。假设我有一个Article模型,整个系统的旅程会是什么样子?我指的是ORM、Controller、API等。如果我在Go中有一个API,ORM会在API级别上,还是我仍然可以使用Rails(它会与API对话)?那么Controller呢?我不知道这个堆栈是否有意义:作为API服务器运行Rails作为应用服务器我担心的是,如果我采用这种方法,我是否会失去Rails附带的很多功能,例如迁移。

linux - Go 二进制文件无法在 openshift 中运行

我在go1.2中开发了一个基本的gorestwebservice。它在我的本地linux机器中按预期工作。但是当我将生成的二进制文件scp到openshift并尝试执行时,它立即终止而没有监听端口。这是应用程序代码:https://gist.github.com/anidotnet/9720936我尝试使用在openshift服务器上编译的二进制文件和在我的本地linux机器上编译的二进制文件,但结果是一样的。尝试使用执行它nohup./app$但它仍然终止。那里也没有panic日志。这里出了什么问题?我错过了什么吗? 最佳答案 我

linux - 如何从Windows部署Go程序到CentOS服务器

我有一个在Windows上运行的Go软件包并且运行良好,但现在我想在生产CentOS6.5服务器上测试它。将其从Windows部署到CentOS的最佳做法是什么?我是否必须使用我的Git存储库分发到Linux操作系统,编译然后将二进制文件部署到服务器?我还有多个文件,所以我想gobuild*.go就足够了,还是有更好的编译选项? 最佳答案 WhatisthebestpracticetodeploythisfromWindowstoCentOS?就最佳实践而言,我建议使用持续集成。您可以设置jenkins,或者那里有一些云选项:cod

Linux 不接受到端口 25 的连接

我在一个简单的smtp服务器上工作,但一直坚持在端口25上接受TCP连接。我尝试运行到服务器并从本地主机使用telnet,它工作正常。在另一台计算机上,它说正在尝试(ip)...当从GMail发送电子邮件到我的smtp服务器时,它没有看到任何连接Golang中的相关代码funcmain(){listener,err:=net.Listen("tcp",":25")checkError(err)for{conn,err:=listener.Accept()checkError(err)gohandleConnection(conn)}}它是一个运行在DigitalOcean上的Ubunt

vim - 开发 Golang 命令行的工作流程

我想要构建我的第一个Go命令行应用程序。我感觉真的很不舒服……做那样的事情时,典型的工作流程会是什么样子?我正在尝试编写一些go然后我在vim中运行gobuild并尝试使用另一个终端选项卡运行该程序,但是gobuild单独没有'似乎无法构建程序并将其安装在我的系统上。我尝试使用-i并且第一次成功了,但之后没有更新它。我敢肯定这很愚蠢,但希望您能为我指明正确的方向。 最佳答案 gobuild&&goinstall成功了! 关于vim-开发Golang命令行的工作流程,我们在StackOve

http - GoLang 服务器上的开发分支,多个 listenAndServes

我正在为我的服务器开发一个分支。这个想法是在两个不同的文件夹中使用同一个git分支的两个克隆,它们或多或少是相同的。第一个文件夹是实时的,第二个是我的开发者。目前,我正在启动live-branchgo项目,稍后将启动developer-branchgo项目。然后,整个网站被镜像到“www.k.com/”和“www.k.com/developer/”。问题是,这行不通。当我启动我的第二个go应用程序时,一切运行正常,但最后一行“http.ListenAndServe”没有捕捉到。据我所知,ListenandServe也不会抛出任何错误。这使我的服务器正常运行,但开发人员/页面抛出404,

go - 无法在travis中构建go项目

我开始创建一个非常轻量级的消息代理来在一个项目中练习go、travis和一些aws服务。我当前的问题是我可以在我的本地机器上构建、运行和测试我的开发分支,但是当travis尝试构建它时我得到一个编译错误。它不喜欢的代码直接来自AWS示例,进一步加深了我的神秘感。Travis构建失败https://travis-ci.org/hevnly/eevy/builds/65687886Githubrepohttps://github.com/hevnly/eevy/tree/92412cf729ed546d698ded1e514d2d54c340ff81错误handler/lambda.go:

linux - 从 Go 访问 Linux 网络 API

我想用Go编写一个简单的实用程序来管理Linux上的网络(有线和无线)连接,类似于NetworkManager和WICD的软件。在Go中访问LinuxAPI的正确方法是什么?我应该使用C绑定(bind)和nativeLinuxAPI调用、执行命令并解析其输出,还是可能有一些库旨在执行我想执行的操作? 最佳答案 您很可能想使用cgo因为调用任何CAPI真的很容易一个额外的好处是,随着时间的推移,CAPI通常非常稳定,因为库创建者几乎总是选择新函数而不是破坏现有函数的API。运行命令行工具和解析输出很容易出错,因为您调用的软件很可能会超

rest - 如何在现实世界的 Go 项目中分离路由、处理程序、第 3 方接口(interface)和业务逻辑

看完officialguide关于如何构建项目和经历各种(1、2、3仅举几例)示例和项目我不禁想知道我构建REST-API服务器应用程序的方法是否结构化正确地。API的用途是什么?POST/auth/sign-in接受用户名和密码并发出JWT(JSON网络token)。GET/auth/sign-out将JWT添加到黑名单以使身份验证session无效。获取/资源检索所有资源的列表。POST/resources(需要有效的JWT身份验证)接受JSON正文,创建新资源并向所有人发送有关新资源的电子邮件和通知。我的项目是什么样的目前我没有创建任何库。一切都在主包中,带有路由的总体服务器设置

linux - 如何编译静态链接的go程序(1.3)?

我正在尝试静态编译一个小的go程序(为了玩Rocket)。我在DebianJessie(薄荷版)上运行。我安装了golang-go包。Rocket文档给出了如何为go版本1.4和1.5进行静态编译的示例1.4$CGO_ENABLED=0GOOS=linuxgobuild-ohello-a-installsuffixcgo.1.5:$CGO_ENABLED=0GOOS=linuxgobuild-ohello-a-tagsnetgo-ldflags'-w'.不幸的是,goversion说我正在运行1.3。$goversiongoversiongo1.3.3linux/amd64我尝试了1.