我可以想到使用C端口和连接的进程,但我想我想要一个相反的情况(前端开始并连接到后端).有命名管道(FIFO),或者我可以通过TCP端口或命名的BSD套接字使用网络通信.有人有这方面的经验吗?
解决方法 一种方法是使应用程序的Erlang核心成为一个守护进程,Cocoa前端通过使用您设计的简单协议通过Unix域套接字进行通信.使用Unix域套接字意味着Erlang守护程序可以由launchd按需启动,Cocoa前端可以找到通过环境变量使用的套接字的路径.这使得应用程序和守护进程之间的会合变得微不足道,它也使得开发多个前端(或者可能包含与守护进程通信的框架)直接相关.
Mac OS X launchd系统真的很酷这样.如果您指定通过安全的Unix域套接字按需启动作业,则launchd实际上将以适当的权限创建套接字本身,并通过作业属性列表中指定的环境变量来宣传其位置.该作业在启动时实际上将在启动时通过launchd将文件描述符传递给套接字.
最终这意味着,即使前端和后台程序以不同的权限运行,前端打开套接字的整个过程与守护进程通信,launchd启动守护程序和响应通信的守护进程也是安全的水平.
总结以上是内存溢出为你收集整理的objective-c – 将可可前端写入Erlang应用程序的好方法是什么?全部内容,希望文章能够帮你解决objective-c – 将可可前端写入Erlang应用程序的好方法是什么?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)