草庐IT

$安全架构

全部标签

用于 Web 应用程序的 node.js golang 复合架构

我目前正在构建一个将使用node.js进行基本路由的网络应用程序。该应用程序的某些部分需要更多处理器,我想对这些部分使用golang。但是,我不确定在两种语言之间安装和通信的最佳方式。我正在使用AmazonElasticBeanstalk进行初始测试,因此任何细节都可以针对该平台。本质上归结为以下两个问题:1)如何在AmazonEC2上同时安装node.js和golangdocker镜像?亚马逊有一个或另一个的指南,但没有两个。2)将处理器密集型任务从node.js卸载到golang代码库的最佳方法是什么(我可以想象RPC,或者只是在某个本地主机端口上运行golang,但我对这种类型的

go - 在 Go 中转换 int 和 int64 时得到不同的输出;是由于处理器架构吗?

我用来测试某些预期行为的应用程序的一小部分会给出不同的输出,具体取决于我运行它的处理器。这是代码的相关部分:forb:=0;b当我在我的Mac(amd64、darwin)上运行它时,我得到如下输出:int64Randomis2991558990735723489int64Randomis7893058381743103687int64Randomis7672635040537837613int64Randomis1557718564618710869int64Randomis2107352926413218802当我在Pi(arm、linux)上运行它时,我得到如下输出:int64Ra

go - 在 mgo 中定义 MongoDB 架构/集合

我想使用mgo创建/保存MongoDB集合。但我想更广泛地定义它(例如,提及其中一个属性是强制性的,另一个是枚举类型并具有默认值)。我已经定义了这样的结构,但不知道如何描述它的约束。typeCompanystruct{Namestring`json:"name"bson:"name"`//-->IWANTTHISTOBEMANDATORYCompanyTypestring`json:"companyType"bson:"companyType"`//-->IWANTTHISTOBEANENUM}这在mgo中是否可行,就像我们如何在MongooseJS中那样做?

go - 在启用安全和隐私的情况下开始对等时出错

当我尝试使用启动对等体时peernodestart出现以下错误hyperledger@linux-box:/opt/gopath/src/github.com/hyperledger/fabric$peernodestart20:42:02.999[crypto]main->INFO001Loglevelrecognized'info',settoINFO20:42:03.017[main]serve->INFO002Securityenabledstatus:true20:42:03.017[main]serve->INFO004Privacyenabledstatus:true20

go - Go中如何使用 channel 安全同步数据

下面是一个如何使用互斥锁来安全访问数据的例子。我如何使用CSP(communicationsequentialprocesses)而不是使用互斥锁和解锁来做同样的事情?typeStackstruct{top*Elementsizeintsync.Mutex}func(ss*Stack)Len()int{ss.Lock()size:=ss.sizess.Unlock()returnsize}func(ss*Stack)Push(valueinterface{}){ss.Lock()ss.top=&Element{value,ss.top}ss.size++ss.Unlock()}func

go - 从内部函数引用外部函数中的值安全吗?

我正从Node.js转向Go,我担心我将在Node中使用的结构在Go中是否安全,以及是否有更惯用的方法来完成同样的事情。我正在使用Echo框架并希望设置一个特定于路由的结构,该结构将在上下文对象中可用。我可以为中间件中的每个调用生成结构,但这样做很昂贵。相反,我在外部函数中设置一次结构,然后返回一个内部函数,该内部函数引用外部函数中的结构。我希望我只承担一次生成成本,然后每次调用都有与我的路由相关联的正确结构。e.POST(path,POST.GenericPostHandler,func(nextecho.HandlerFunc)echo.HandlerFunc{operation:

go - 为用户可以编辑的页面(例如维基百科/stackoverflow 页面)设计数据存储架构

想法是设计一个表/实体,其中包含一些基本信息,以及一个Markdown-Content字段,允许用户轻松创建表等。我是这样想的:typeTournamentstruct{IDin64`datastore:"-"`MDContent[]byte`datastore:",noindex"`NamestringURLstringDateCreatedint64CreatedBystringDateUpdatedint64UpdatedBystringApprovalStatusint64//0=tobedecided,1=approved,2=rejected,3=discontinuedA

amazon-web-services - 您如何在无服务器架构中平衡 nosql 存储和缓存?

我正在为无服务器环境(aws)编写一个基于go的应用程序。我对编写应用级代码还很陌生,而且我有基础架构背景。我知道缓存不是持久性的,但我真的需要关心真正无服务器环境中的持久性吗?从需求的角度来看,简单的dynamodb表可以满足我的存储需求,但缓存会给我更好的性能,对吧?我需要性能,这是我为应用程序使用go的一个重要原因。 最佳答案 您可以选择AWSElastiCache(redis或memcache),但这并不是真正的无服务器,因此可能不是一个选择。AWSLambda允许您在/tmp目录中写入,您可以在内存中缓存一些内容。不过,我

go - 如何安全地将我的数据库结果缓存在内存缓存中

我有返回用户的函数。我正在为我的数据库ORM使用gorm:func(dbs*DbService)GetUser(userIdstring)User{varuser=&User{}dbs.db..Find(&user)returnuser}如果我缓存结果,即用户,这是否会导致内存分配问题,因为我将用户放在引用类型的缓存中,所以它会导致变量user超出此函数的范围?更新鉴于上述功能,我想使用memcache将其更新为缓存(下面不是存储我的用户的实际代码,只是一个例子):mc.Set(&memcache.Item{Key:"foo",Value:[]byte("myvalue")})这是进程

database - 这种数据访问模式是线程安全的吗?

我已经通过以下实现实现了dao.go文件:类型DbClient结构{db*gorm.DB}GetDBClient()初始化与数据库的连接并返回(*DbClient,error)func(db*DbClient)Close(){db.db.关闭()}DbClient的不同增删改查方法服务于所有处理程序的main.go文件像这样使用它:vardbClient*DbClientfuncmain(){db,err:=GetDBClient()iferr!=nil{panic(err)}dbClient=dbdeferdbClient.Close()...}因此main.go的所有处理程序都使用