脚本语言使用的套接字与编译语言完全相同.
1)脚本通常打开并使用套接字.它不是由套接字"运行"或"调用",而是通过库直接控制它(通常调用OS的本机C API).
2)是的.
3)不一定.大多数现代脚本语言都可以在一个"脚本"应用程序中处理多个套接字.
4)N/A,见3)
编辑以回应问题和评论的变化:
现在很明显,您正尝试在托管服务器的上下文中运行它.通常,如果您在Apache或类似服务器中使用脚本,则情况会有所不同.套接字由Apache打开并维护,它执行您的脚本,将相关数据(POST/GET结果等)传递给您的脚本进行处理.当您处理CGI脚本等时,套接字通常不起作用.
但是,这通常使用与mod_cgi相同的概念.这几乎意味着,就服务器而言,运行的脚本只是一个可执行文件,可执行文件的输出是返回给客户端的输出.在这种情况下,(如果你有权限和服务器上的正确库),你的python脚本实际上可以启动一个单独的脚本,它完全在Apache的上下文之外完成自己的套接字工作.
但是,直接在CGI脚本中运行完整套接字实现(通常)不是一个好主意.CGI将期望可执行文件在将结果返回给客户端之前运行完成.Apache将坐在那里并"等待"等待完成.如果您正在启动一个完整的服务器(特别是如果它是一个长期运行的进程,它们往往是),Apache会认为该脚本已被锁定,可能会中止,可能会导致该进程被终止(特定于配置,但大多数托管公司会这样做)防止脚本在共享系统上接管CPU.
但是,如果从脚本中执行新脚本,然后返回(关闭CGI可执行文件),则另一个脚本可以保持运行,作为服务器运行.这将是(python示例,使用子进程库):
newProccess = Popen("python MyScript", shell=True)
Run Code Online (Sandbox Code Playgroud)
请注意,上述所有内容实际上都取决于服务器配置.许多托管公司在其脚本实现中不包含一些套接字或shell库,专门用于防止这种情况,因此您经常需要恢复在C中创建可执行文件.此外,这通常违反了大多数托管公司的服务条款 - 你必须检查你的.