gpt4 book ai didi

python - 在具有多个类的 CherryPy Python Web 应用程序中配置主机和端口

转载 作者:太空宇宙 更新时间:2023-11-03 19:01:30 24 4
gpt4 key购买 nike

我有一个简单的 Cherrypy Web 应用程序,包括两个类。初始化代码如下所示:

c = MyClass()
c.updates = AnotherClass()
app = cherrypy.tree.mount(c, '/', 'myapp.config')
c.setConfig(app.config)
c.updates.setConfig(app.config)
cherrypy.engine.start()
cherrypy.engine.block()

这两个类的 setConfig 方法只是一行代码来存储一些数据库配置:

def setConfig(self, conf):
self.config = conf['Database']

配置文件 myapp.config 如下所示:

[global]
server.socket_host = "0.0.0.0"
server.socket_port = 80

[/]
tools.staticdir.root = com.stuff.myapp.rootDir + '/html'

[Database]
dbtable: "mydbtable"
username: "user"
password: "pass"

当我启动该批处理时,应用程序获取数据库配置数据,并正确地从/html 目录提供静态文件,但它仅监听 8080 上的本地主机。我在控制台上得到此信息:

[11/Apr/2013:10:03:58] ENGINE Bus STARTING
[11/Apr/2013:10:03:58] ENGINE Started monitor thread 'Autoreloader'.
[11/Apr/2013:10:03:58] ENGINE Started monitor thread '_TimeoutMonitor'.
[11/Apr/2013:10:03:58] ENGINE Serving on 127.0.0.1:8080
[11/Apr/2013:10:03:58] ENGINE Bus STARTED

我肯定做错了什么。就好像配置的全局部分没有被应用。我该如何修复它?

最佳答案

我想我已经知道如何解决这个问题了。我添加了这一行:

cherrypy.config.update('myapp.config')

在这行之后

app = cherrypy.tree.mount(c, '/', 'myapp.config')

我认为我的类获取数据库配置的原因是我通过 setConfig() 调用手动传递它。这仅传递应用程序配置,而不是全局配置。 mount() 调用显然不会将配置数据传播到它所挂载的对象,正如我认为的那样。

此外,update() 调用必须在 mount() 调用之后,否则会引发异常。

我不确定这是否是组织此代码的最佳方式。目前这可行,但更好的想法总是受欢迎的。

关于python - 在具有多个类的 CherryPy Python Web 应用程序中配置主机和端口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15945772/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com