www.9778.com 12

Node.js 13.0.3 发布,重做 rmdir()

显著变化

  • fs
    • 重做rmdir() 递归 (cjihrig)#30644
      • maxBusyTries选项被重命名为maxRetries,其默认值为0。该emfileWait选项已被删除,并且EMFILE的错误
        使用与其他错误相同的重试逻辑。retryDelay已经支持该选项。ENFILE现在错误会进行重试。
  • http
    • 使每个流或每个服务器的最大标头大小可配置(Anna
      Henningsen)#30570
  • http2
    • 使最大允许的流可配置(Denys
      Otrishko)#30534
    • 允许配置最大容许的无效帧(Denys
      Otrishko)#30534
  • wasi
    • 引入初步的WASI支持(Cjihrig)#30258

其他 179 项更新: 

(文/开源中国)    

:

模块

   IIS Web Core

通知

   BeginRequest

处理程序

   尚未确定

错误代码

   0x80070021

配置错误

   不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认设置的(overrideModeDefault=”Deny”),或者是通过包含
overrideMode=”Deny” 或旧有的
allowOverride=”false” 的位置标记明确设置的。

配置文件

   \?D:websiteyuanjingweb.config

请求的
URL

   

物理路径

   D:websiteyuanjing

登录方法

   尚未确定

登录用户

   尚未确定

 

 

 

 

配置源

状态

Node.js 13.0.3 发布,重做 rmdir()。link

复制代码 代码如下:

Node.js 13.0.3 已经发布。

:

   84:     <validation validateIntegratedModeConfiguration="false"/>

   85:     <modules runAllManagedModulesForAllRequests="true"/>

   86:     <handlers>

www.9778.com 1

可以在命令行运行

%windir%system32inetsrvappcmd unlock config
-section:system.webServer/modules

注意:cmd.exe要以管理员身份启动。

www.9778.com 2

 

 

acks_late选项

task在经过worker确认(acknowledge)之后,才会从worker的任务队列中移除。并且worker维护的任务队列可以保留相当大量的队列信息,即使这个worker被杀掉,任务信息仍然可以转移到其他的worker

  • broker在收到来自worker的确认之后,便不会发送任务信息给其他的worker

  • worker默认的确认时机:任务信息被worker接收

  • 设置了acks_late选项之后,worker的确认时机变为任务被实际执行

  • 在保证taskidempotent(幂等的),即任意次执行代码所产生的影响和一次执行的影响相同,可以使用acks_late选项

  • http://docs.celeryproject.org/en/master/userguide/tasks.html#Task.acks_late

  • http://docs.celeryproject.org/en/master/faq.html#faq-acks-late-vs-retry

请大家注意,虚拟机配置发生改变后,一定要restart。
(六)加入PHP支持 这时,我们的APACHE只能支持静态的以HTML或者HTM结尾的文件,想要支持PHP还得进行如下操作:
#rpm -qa | grep
php,查询本机是否已经安装了PHP程序,如果没有安装,则进入光盘中的CENTOS目录,在目录的空白处打开终端:
#rpm -ivh php-common-5.1.6-20.el5.i386.rpm
#rpm -ivh php-cli-5.1.6-20.el5.i386.rpm
#rpm -ivh php-5.1.6-20.el5.i386.rpm
这时,在/var/www/html目录下新建一个ok.php脚本,写入以下内容:
在浏览器中输入“
处于历史原因,有些程序是以.php3或.php4为结尾的。我们需要在php的配置文件中进行修改,打开/etc/httpd/conf.d/php.conf
修改“#AddType application/x-httpd-php-source .php”为“AddType
application/x-httpd-php-source .php .php3
.php4”,要去掉#,在.php3/4前是有空格的

无法访问请求的页面,因为该页的相关配置数据无效。

详细错误信息

无限期阻塞的任务

由于网络传输等问题,导致任务无限期阻塞,会阻止此worker实例执行其他工作,解决方案是:

  • I/O任务:确保添加超时(可配合retry)。例如:使用requests

connect_timeout, read_timeout = 5.0, 30.0
response = requests.get(URL, timeout=(connect_timeout, read_timeout))
  • time limits选项也可以很方便地规定任务遵循一个时间限制,但是这个时间过后,这个worker会被直接杀掉,所以该选项仅用于没有使用其他超时方案的情况
    (http://docs.celeryproject.org/en/master/userguide/workers.html#worker-time-limits)

<VirtualHost www.web1.com>
ServerName www.web1.com:80
DocumentRoot /var/www/web1
DirectoryIndex index.html index.htm
</VirtualHost>
<VirtualHost www.web2.com>
ServerName www.web2.com:80
DocumentRoot /var/www/web2
DirectoryIndex index.html index.htm
</VirtualHost>

windows server 2012 r2 iis8.5 部署asp.net mvc4/5程序小结

Handlers

在任务返回、失败、重试、成功、超时等事件发生的时候,触发特定的方法:after_return,
on_failure, on_retry, on_success, on_timeout

可用于状态转移的监控,如发邮件提醒等

一个自定义请求的例子如下

import logging
from celery.worker.request import Request

logger = logging.getLogger('my.package')

class MyRequest(Request):
    'A minimal custom request to log failures and hard time limits.'

    def on_timeout(self, soft, timeout):
        super(MyRequest, self).on_timeout(soft, timeout)
        if not soft:
           logger.warning(
               'A hard timeout was enforced for task %s',
               self.task.name
           )

    def on_failure(self, exc_info, send_failed_event=True, return_ok=False):
        super(Request, self).on_failure(
            exc_info,
            send_failed_event=send_failed_event,
            return_ok=return_ok
        )
        logger.warning(
            'Failure detected for task %s',
            self.task.name
        )

class MyTask(Task):
    Request = MyRequest  # you can use a FQN 'my.package:MyRequest'

@app.task(base=MyTask)
def some_longrunning_task():
    # use your imagination

如果本机只有一个网卡,那么就得在这一块网卡上绑定多IP:

原文链接:

task方法选项列表

类似@app.task(option1=xx, option2=yy),括号内的参数即选项
http://docs.celeryproject.org/en/master/userguide/tasks.html#general

一些选项(部分参考文档即可):

  • max_retries:
    只有在任务调用self.retry或者任务使用autoretry_for参数进行装饰时才适用
  • throws:
    值是tuple类型,里面的“异常”不会被视为错误而导致失败或重发,即使发生,也是成功的
  • default_retry_delay: 重试间隔时间
  • rate_limit:
    关联task_default_rate_limit这个设置,表示某个时间段执行的任务数目,如:"100/m"表示一分钟最多100条。默认无限制
  • time_limit / soft_time_limit:
    任务完成的时间限制。前者是经过时限之后worker被杀死,然后用新worker代替,后者是经过时限之后抛出SoftTimeLimitExceeded异常,供开发者处理。默认没有时限。
  • ignore_result / store_errors_even_if_ignored
  • name
  • request
  • serializer
  • compression
  • backend
  • ack_late
  • track_started

4、应用文件
/usr/sbin 存放Apache WEB服务器程序文件和应用程序的位置
/usr/doc/ 放置Apache WEB服务器文档
/var/log/http 放置Apache 日志文件的位置
四、更多命令
1、查看Apache安装信息:apachectl -C
2、对Apache的配置文件进行语法检查:apachectl -t
3、查看Apache编译配置参数:apachectl -V
4、查看Apache的编译模块:apachectl -l
五、httpd.conf配置文件 (一)基本配置
httpd.conf文件包含为下面三个部分:

HTTP 错误 500.19 – Internal Server Error

task options

@app.task(options…)

link

3、基于域名的虚拟主机
NameVirtualHost 192.168.0.94:

基本配置

打开服务器管理器,点击添加角色和功能。

www.9778.com 3

选择基于角色或基于功能的安装。

www.9778.com 4

选择服务器。

www.9778.com 5

选择webserver(iis)

www.9778.com 6

 

选择角色。

www.9778.com 7

打开web服务器(IIS)选项。选择常见http功能。

www.9778.com 8

安全性选择中勾选常用的安全性选项。

www.9778.com 9

应用程序开发选项中,请确保选择.net 3.5,.net 4.5,ISAPI扩展。

www.9778.com 10

开始安装。

参数检测(typing)

>>> @app.task
... def add(x, y):
...     return x + y

# Calling the task with two arguments works:
>>> add.delay(8, 8)
<AsyncResult: f59d71ca-1549-43e0-be41-4e8821a83c0c>

# Calling the task with only one argument fails:
>>> add.delay(8)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "celery/app/task.py", line 376, in delay
    return self.apply_async(args, kwargs)
  File "celery/app/task.py", line 485, in apply_async
    check_arguments(*(args or ()), **(kwargs or {}))
TypeError: add() takes exactly 2 arguments (1 given)

# typing 属性
>>> @app.task(typing=False)
... def add(x, y):
...     return x + y

# Works locally, but the worker reciving the task will raise an error.
>>> add.delay(8)
<AsyncResult: f59d71ca-1549-43e0-be41-4e8821a83c0c>

说明:
allow和deny可以用于apache的conf文件或者.htaccess文件中(配合Directory,
Location, Files等),用来控制目录和文件的访问授权。
所以,最常用的是:
Order Deny,Allow Allow from
All注意“Deny,Allow”中间只有一个逗号,也只能有一个逗号,有空格都会出错;单词的大小写不限。上面设定的含义是先设定“先检查禁止设定,没有禁止的全部允许”,而第二句没有Deny,也就是没有禁止访问的设定,直接就是允许所有访问了。这个主要是用来确保或者覆盖上级目录的设置,开放所有内容的访问权。
按照上面的解释,下面的设定是无条件禁止访问:
Order Allow,Deny Deny from
All如果要禁止部分内容的访问,其他的全部开放:
Order Deny,Allow Deny from ip1 ip2或者
Order Allow,Deny Allow from all Deny from ip1
ip2apache会按照order决定最后使用哪一条规则,比如上面的第二种方式,虽然第二句allow允许了访问,但由于在order中allow不是最后规则,因此还需要看有没有deny规则,于是到了第三句,符合ip1和ip2的访问就被禁止了。注意,order决定的“最后”规则非常重要,下面是两个错误的例子和改正方式:
Order Deny,Allow Allow from all Deny from
domain.org错误:想禁止来自domain.org的访问,但是deny不是最后规则,apache在处理到第二句allow的时候就已经匹配成功,根本就不会去看第三句。
解决方法:Order Allow,Deny,后面两句不动,即可。
Order Allow,Deny Allow from ip1 Deny from
all错误:想只允许来自ip1的访问,但是,虽然第二句中设定了allow规则,由于order中deny在后,所以会以第三句deny为准,而第三句的范围中又明显包含了ip1(all
include ip1),所以所有的访问都被禁止了。
解决方法一:直接去掉第三句。
解决方法二:
Order Deny,Allow Deny from all Allow from ip1小结:规律就是order
deny,allow表示deny优先级低而allow优先级高,order
allow,deny表示allow优先级低而deny优先级高。
(三)创建虚拟目录
如果我们的网站建在了别的目录,比如/opt/www/lk下,是不是不在主目录/var/www/html下就不能访问了呢?当然不是。
可以使用虚拟目录,让用户访问到别的目录下的文件。虚拟目录是位于Apache主目录外的其他目录,一般我们通过为虚拟目录创建别名的方式来让web访问。这样做一是安全;二是访问简单,不用输入那么长的真是目录地址,而只用输入一个简单的别名就行;三是便于站点目录的移动,只要虚拟目录名不变,改变实际存放位置,不会影响web访问的。
我们用Alias选项创建虚拟目录,如Alias /bbs/ “/opt/www/lk/”<Directory
“/opt/www/lk/”> Options Indexes MultiViews AllowOverride None Order
allow,deny Allow from all</Directory>
(四)进行用户认证
用户认证是网络安全中极为重要的一个部分,让想访问指定网站的用户输入用户名和密码才能进行登录,起到了天然的安全屏障作用。Apache的安全认证在实际使用中也是很常见的。现在就通过一个例子演示如果在Apache服务器中实现用户认证的功能。
我们对上述的虚拟目录进行操作: Alias /bbs/ “/opt/www/lk/”<Directory
“/opt/www/lk/”> Options Indexes MultiViews AllowOverride None Order
allow,deny Allow from all AuthType:Basic AuthName “welcome go home:”
AuthUserFile /etc/httpd/authpwd Require user laoda
laoer</Directory> 说明:
AuthType:定义了对用户认证的类型,常用的是mod_auth提供的Basic;
AuthName:Web浏览器显示在输入用户名和密码框时的提示文字;
AuthUserFile:定义口令文件htpasswd的路径; Require
user:定义了允许访问的用户名单,名字间用空格分隔。
之后,建立authpwd文件用来保存密码,touch /etc/httpd/authpwd
接着,把用户名和密码写入文件(注意:第一次创建用户时使用-c参数,第二个用户被创建就不必写了,否则会覆盖刚才的用户):
[root@localhost http]#htpasswd -c /etc/httpd/authpwd laoda New
password: Re-type new password: Add password for user
laoda[root@localhost http]#htpasswd /etc/httpd/authpwd laoer New
password: Re-type new password: Add password for user laoer 现在service
httpd restart,再用浏览器访问这台linux的IP地址即可。
(五)配置虚拟主机为了节省费用和提高服务器的利用效率,我们可以在一台机器上建立出多台“主机”。每个主机都能对外提供WEB服务,在外界看来是些不同的网站,但对服务器而言,其实看似不同的网站,其实它们都是运行于同一台主机之上的不同的虚拟主机而已。如何配置虚拟主机呢?Apache的虚拟主机功能是非常强大的,而且配置很简单。主要分为基于IP和基于域名的虚拟主机。我们先配置基于IP的虚拟主机吧。这其中也有两种选择,你现在有多少个可用IP?如果你购买了不少IP,那么你可以给每个虚拟主机分配不同的IP,让他们使用相同的端口,这是其一。如果在这个IP短缺的时代,你没哟那么多IP,只买了一个,那么你就可以使用一个IP地址加不同端口的方式,让不同的端口访问不同的虚拟主机。1、IP地址相同,但端口号不同:现在我的CentOS上,只有一个IP:192.168.0.94,我想分别使用8080和8081两个端口配置两个网站,编辑httpd.conf:Listen
8080Listen 8081<VirtualHost 192.168.0.94:8080>DocumentRoot
/var/www/web1DirectoryIndex index.html index.htmHostNameLookups
off</VirtualHost><VirtualHost 192.168.0.94:8081>DocumentRoot
/var/www/web2DirectoryIndex index.html index.htmHostNameLookups
off</VirtualHost>重启服务,即可。
2、端口号相同,但IP地址不同,假如一个是94,一个是95:

:

模块

   IIS Web Core

通知

   BeginRequest

处理程序

   尚未确定

错误代码

   0x80070021

配置错误

   不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认设置的(overrideModeDefault=”Deny”),或者是通过包含
overrideMode=”Deny” 或旧有的
allowOverride=”false” 的位置标记明确设置的。

配置文件

   \?D:websiteyuanjingweb.config

请求的
URL

   

物理路径

   D:websiteyuanjing

登录方法

   尚未确定

登录用户

   尚未确定

 

 

 

 

配置源

Celery 进阶学习

参考链接: Celery 4.1.0
documentation

ifconfig eth0:1 192.168.0.95

无法访问请求的页面,因为该页的相关配置数据无效。

详细错误信息

初始文件

安装部署celery相关的pip包,参考文档或Celery
部署小记

另外,本文使用ipython作为控制台的交互式解释器,pip install ipython

tasks.py例1

from celery import Celery


class CeleryConfig():
    broker_url = 'redis://localhost'
    result_backend = 'redis://localhost'
    timezone = 'Asia/Shanghai'


app = Celery()
app.config_from_object(CeleryConfig)


@app.task
def add(a, b):
    return a + b

以上文件可以正常通过以下命令启动

celery -A tasks worker --loglevel=info

例1中使用类的方式来加载配置,其他方式有:

Configuration

  • app.conf.timezone = 'Asia/Shanghai'
    app.conf.update(option1=True, option2='xxx', ...)
  • app.config_from_object(param)方法,参数可以是模块名的字符串形式、模块对象实体、配置的类或对象等
  • app.config_from_envvar(param)方法,参数是系统的环境变量名,而这个变量对应的值是模块的字符串。如:os.environ.setdefault('CELERY_CONFIG_MODULE', 'celeryconfig')

注意从现在开始必须制定开启特殊的权限,这样就不会产生意想不到的结果。请仔细确认。
例如:

HTTP 错误 500.19 – Internal Server Error

最佳实践

Tips and Best
Practices

Optimizing

  1. 忽略不需要的结果,ignore_result=True
  2. 尽量避免使用同步子任务(task调用需要依赖其他task执行的结果,这样会造成互相等待,陷入死锁)
    Avoid launching synchronous
    subtasks
  3. 设置broker_pool_limit,默认为10,可以根据使用连接的线程的数目调整
    link
  4. worker_prefetch_multiplierwww.9778.com,表示一次prefetch多少条消息乘以并发进程数,默认值为4(每个进程4个消息)。对于长时间的任务,可以把这个值设置为1,其实就相当于关闭预取;对于短时任务,可以设置大一些,比如64,128等;对于长短不一的任务,可以通过Routing
    Tasks,即分队列的方式执行
  5. 针对长任务,许多人希望的是让当前执行的任务数与保留待确认的任务数目相同,且都等于当前并发数(如-c 10,此时在执行的任务是10个,等待的任务数也是10个)。满足这样的要求选项:task_acks_late = Trueworker_prefetch_multiplier = 1
  6. 在默认的prefork模式下,进程池中的进程可能处于空闲或忙碌的状态。-O是优化选项,如果是default,进程是预取来自worker中的任务的,可能造成长时间的等待;如果是fair,进程只在有空闲的时候,才会去取任务执行。设置fair对于耗时长的任务来说比较有利

练习1:
自己在CentOS上使用服务器建立Web服务器,设置“/opt/自己名字的拼音”为新创建的虚拟目录,此虚拟目录别名是“exam”,在此虚拟目录下自己新建一个html文档名为“index.htm”,<body>中内容是“写入你自己的名字”。创建apache用户认证,添加两个用户user1(密码123456)和user2(密码654321),最后用浏览器访问“ip/exam/:8080”便可以看到显示你名字的网页,即可。
练习2:
配置虚拟主机。思考,如何配置一台虚拟主机,其上跑着四个网站,分别是192.168.0.101跑web1,192.168.0.102跑web2,192.168.0.100上跑www.cba.com和www.nba.com两个网站。

:

   79:     <modules runAllManagedModulesForAllRequests="true" />

   80:     <handlers>

   81:       <remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" />

www.9778.com 11

解决方案:

出现这个错误是因为从 IIS
7开始采用了更安全的
web.config 管理机制,默认情况下会锁住配置项不允许更改。要取消锁定可以运行命令行

 %windir%system32inetsrvappcmd unlock config
-section:system.webServer/handlers 。其中的
handlers 是错误信息中红字显示的节点名称。 
如果modules也被锁定。

重试(Retrying)

当任务执行出现错误情况,可以通过设置retry来解决可恢复的错误。celeryretry机制会确保由相同的队列去执行此task-id的原始任务。简单的例子如下

@app.task(bind=True)
def send_twitter_status(self, oauth, tweet):
    try:
        twitter = Twitter(oauth)
        twitter.update_status(tweet)
    except (Twitter.FailWhaleError, Twitter.LoginError) as exc:
        raise self.retry(exc=exc)

特别注意,retryraise出来的,所以,即使后面有代码,也不会执行。另外,这个异常会被worker视为需要重试,以便在启用result backend时,可以存储正确的状态(RETRY)

重试的各种选项和应用:

以下是@app.task的参数

  • max_retries:
    当超过该参数设置的重试次数,会终止并报错。默认是3次,设置为None表示不重试
  • default_retry_delay:
    默认重试间隔时间。默认是180s,可以在retry调用中使用countdown参数覆盖
  • autoretry_for:
    对特定的异常自动重试,如autoretry_for=(Exception,),仅适用于v4.0
  • retry_kwargs: 后面接字典类型,如retry_kwargs={'max_retries': 5}

以下三个选项是v4.1版本支持的

  • retry_backoff:
    可以是布尔型或者数字,如果设置为True,则遵循“指数退避”,即第一次重试在1s后,第二次2s,第三次4s,第n次(2^(n-1))s。
    如果设置为数字m,则表示基数为m,即第一次3s,第二次6s,第n次(3×2^(n-1))s。
    如果设置为False,则表示不延迟
  • retry_backoff_max:
    如果retry_backoff打开,这个选项决定了两次自动重试之间最大的延时,超过了这个延时,则不再重试。默认600s
    (这里理解可能有问题?需要具体测试: If retry_backoff is enabled,
    this option will set a maximum delay in seconds between task
    autoretries. By default, this option is set to 600, which is 10
    minutes.)
  • retry_jitter:
    布尔型,jitter(抖动)。抖动用于将随机性引入指数退避延迟,以防队列中过多的任务同时被执行。如果设置为True,则retry_backoff计算的延迟值将被视为最大值,而实际延迟值将是介于0和最大值之间的随机数。该设置默认为True

<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>

常见错误

TTP 错误 403.14 – Forbidden

Web 服务器被配置为不列出此目录的内容。

最可能的原因:

·        
没有为请求的 URL 配置默认文档,并且没有在服务器上启用目录浏览。

可尝试的操作:

·        
如果不希望启用目录浏览,请确保配置了默认文档并且该文件存在。

·        
使用 IIS 管理器启用目录浏览。

1.   
打开 IIS 管理器。

2.   
在“功能”视图中,双击“目录浏览”。

3.   
在“目录浏览”页上,在“操作”窗格中单击“启用”。

·        
确认站点或应用程序配置文件中的 configuration/system.webServer/directoryBrowse@enabled
特性被设置为 True。

详细错误信息:

模块

   DirectoryListingModule

通知

   ExecuteRequestHandler

处理程序

   StaticFile

错误代码

   0x00000000

请求的 URL

   

物理路径

   D:websiteyuanjing

登录方法

   匿名

登录用户

   匿名

 

 

 

 

 

www.9778.com 12

解决方案:

1)         发布时不要选择预编译,否则会出现这样的错误;

2)         站点所在的文件夹,保证iis有访问和控制权限。

 

 

抽象任务(类)

所有task都必须使用@app.task装饰器来装饰,经过装饰器之后,这些任务会继承Task类。可以通过继承Task类,来创建一个抽象类,供task装饰

tasks.py例2

from celery import Celery


# 抽象tasks
from celery import Task
class DebugTask(Task):
    # 在调用之前打印一行字
    def __call__(self, *args, **kwargs):
        print('TASK STARTING: {0.name}[{0.request.id}]'.format(self))
        return super(DebugTask, self).__call__(*args, **kwargs)


class CeleryConfig():
    broker_url = 'redis://localhost'
    result_backend = 'redis://localhost'
    timezone = 'Asia/Shanghai'


app = Celery()
app.config_from_object(CeleryConfig)


@app.task(base=DebugTask)
def add(a, b):
    return a + b

ipython调试

In [1]: from tasks import add

In [2]: add.delay(2, 3)
Out[2]: <AsyncResult: d9e63190-0591-403d-a5be-8b59893fcb2d>

celery输出

[2017-11-20 15:52:05,660: INFO/MainProcess] Received task: tasks.add[d9e63190-0591-403d-a5be-8b59893fcb2d]  
[2017-11-20 15:52:05,662: WARNING/ForkPoolWorker-4] TASK STARTING: tasks.add[d9e63190-0591-403d-a5be-8b59893fcb2d]
[2017-11-20 15:52:05,666: INFO/ForkPoolWorker-4] Task tasks.add[d9e63190-0591-403d-a5be-8b59893fcb2d] succeeded in 0.00480927500029793s: 5

复制代码 代码如下:

隐藏敏感信息(避免进入log)

v4.0之后,且task_protocol为2或以上才有效(该值在4.0之后默认为2)

可以使用argsreprkwargsrepr调用参数来覆盖敏感信息,例子如下

>>> add.apply_async((2, 3), argsrepr='(<secret-x>, <secret-y>)')

>>> charge.s(account, card='1234 5678 1234 5678').set(
...     kwargsrepr=repr({'card': '**** **** **** 5678'})
... ).delay()

但实际上,只要可以从broker中读取数据,仍然可以获得这些“敏感信息”,所以如果需要高度保密的数据,要使用其他方法存储(加密等)

<Directory “D:/www_root”>
#
# 此值可是: “None”, “All”, 或下列的组合: “Indexes”,
# “Includes”, “FollowSymLinks”, “ExecCGI”, 或 “MultiViews”.
# 注意”MultiViews”必须明确指定— “Options All”不包括此特性。
#
Options Indexes FollowSymLinks MultiViews
#
# 此项控制目录中哪些.htaccess文件可覆盖。
# 允许值: “All”或者以下项的组合:”Options”, “FileInfo”,
# “AuthConfig”, “Limit”
#
AllowOverride None
#
# 控制哪些用户可从此服务器获得资料。
#
Order allow,deny
Allow from all
</Directory>

logging

worker会自动建立log,当然你也可以自定义log,例子如下

from celery.utils.log import get_task_logger

logger = get_task_logger(__name__)

@app.task
def add(x, y):
    logger.info('Adding {0} + {1}'.format(x, y))
    return x + y

然后大家在,linux下的/etc/hosts文件或者windows下C:WINNTsystem32driversetchosts文件中,加入
192.168.0.94 www.web1.com
192.168.0.94 www.web2.com

Prefork池预取设置

prefork池默认将异步发送尽可能多的任务到进程中(进程预取任务)。对于延时短的任务,这样会加快速度,但是如果是高延时的任务,该进程后面的任务会长期处于等待。

默认设置: worker会发送任务给缓冲区可写的进程,例子如下

-> send task T1 to process A
# A executes T1
-> send task T2 to process B
# B executes T2
<- T2 complete sent by process B

-> send task T3 to process A
# A still executing T1, T3 stuck in local buffer and won't start until
# T1 returns, and other queued tasks won't be sent to idle processes
<- T1 complete sent by process A
# A executes T3

使用-Ofair选项可以关闭预取设置,此时,worker会发送任务给真正可用于工作的进程,例子如下

-> send task T1 to process A
# A executes T1
-> send task T2 to process B
# B executes T2
<- T2 complete sent by process B

-> send T3 to process B
# B executes T3

<- T3 complete sent by process B
<- T1 complete sent by process A

复制代码 代码如下:

一、WEB服务器与Apache 1、web服务器与网址
2、Apache的历史
3、补充

同时必须注意的是ngnix,正处于强势增长的上升时期,大有和apache一争天下的感觉,真是后生可畏~~~
二、Apache服务器的管理命令
1、命令启动:service httpd
start/stop/restart/reload/condrestart/status/configtest/graceful/help
2、脚本启动:/etc/init.d/httpd start/stop/…..
3、设为开机自动启动:ntsysv+空格键
三、Apache服务器的目录和文件
1、WEB站点目录
/var/www Apache站点文件的目录
/var/www/html 存放WEB站点的WEB文件
/var/www/cgi-bin CGI程序文件
/var/www/html/manual Apache WEB服务器手册

您可能感兴趣的文章:

  • Apache
    SSL服务器配置SSL详解
  • PHP
    服务器配置(使用Apache及IIS两种方法)
  • CentOS 5.4 服务器配置
    yum安装Apache+php+Mysql
  • PHP开发Apache服务器配置
  • 跨域请求 Apache
    服务器配置的方法
  • Apache实现多端口多主机名配置

3、启动脚本
/etc/rc.d/init.d/httpd WEB服务器守护进程的启动脚本
/etc/rc.d/rc3.d/S85httpd
将运行级目录(/etc/rc3.d)连接到目录/etc/rc.d/init.d中的启动脚本

<VirtualHost 192.168.0.94>
ServerName 192.168.0.94:80
DocumentRoot /var/www/web1
DirectoryIndex index.html index.htm
</VirtualHost>
<VirtualHost 192.168.0.95>
ServerName 192.168.0.95:80
DocumentRoot /var/www/web2
DirectoryIndex index.html index.htm
</VirtualHost>

  1. 全局环境设置:控制整个Apache服务器行为的部分(即全局环境变量)
    2.
    主服务器配置:定义主要或者默认服务参数的指令,也为所有虚拟主机提供默认的设置参数
  2. 虚拟主机设置:虚拟主机的设置参数
    其中,一行写不下使用“”表示换行,除了选项的参数值外,所有选项指令不区分大小写,“#”表示注释。
    现在,我们来学习httpd.conf中的具体设置项:
    1.设置相对根目录的路径
    相对根目录通常是Apache存放配置文件和日志文件的地方,通常情况下相对根目录是”/etc/httpd”,它一般包含conf和logs子目录,此时可以采用”ServerRoot”/etc/httpd””格式进行设置。
    2.设置Apache监听的IP地址和端口号
    Apache默认会在本机所有可用IP地址上的TCP
    80端口监听客户端的请求,可以使用Listen语句以便在某个指定地址和端口上监听请求。例如设置服务器只监听192.168.0.94的80端口,则可以在httpd.conf中进行相应的设置:Listen
    192.168.0.94:80。如果需要更改端口号为8080,也可以采用”Listen
    192.168.0.94:8080″之类的设置,但是此时通过网页浏览器访问网站的时候也必须在域名地址后面添加相应的端口号,例如输入”
    3.设置网络管理员的电子邮件地址
    当客户端计算机访问服务器发生错误的时候,服务器通常都会向客户端计算机返回错误提示页面,为了方便解决错误,在这个网页中通常包含有管理员的电子邮件地址,此时可以采用ServerAdmin语句来设置管理员的电子邮件地址,例如”ServerAdmin
    xinyuan365@sohu.com”。
    4.设置服务器主机名称
    为了方便Apache识别服务器自身的信息,可以使用ServerName语句来设置服务器的主机名称。在ServerName语句中,如果服务器有域名则填写服务器的域名;如果没有域名,则填入服务器的IP地址。例如”ServerName
    192.168.0.94:80″。
    5.设置主目录的路径
    Apache服务器主目录默认路径为”/var/www/html”,可以将需要发布的网页放置在这个目录中,同时也可以把主目录的路径修改为别的目录便于用户管理和使用。例如需要将Apache服务器主目录路径设置为”/home/lk/www”,则可以在httpd.conf文件中进行相应修改:DocumentRoot
    “/home/www”。
    6.设置默认文档
    默认文档是指在网页浏览器中输入Web站点的IP地址或者域名显示出来的Web页面,也就是通常所说的主页。在缺省情况下,Apache的默认文档名为index.html,默认文档由DirectoryIndex语句进行定义,例如在httpd.conf中通过”DirectoryIndex
    index.html
    index.html.var”进行设置,此时可以将DirectoryIndex语句的默认文档名修改为其他文件。
    如果有多个文件名,每个文件名之间必须用空格进行分隔,Apache会根据文件名的先后顺序查找在DirectoryIndex语句中指定的文件名。如果能找到第1个则调用第1个,否则再寻找并调用第2个,依次类推。例如添加index.htm和index.php文件作为默认文档,则可以相应修改httpd.conf文件为”DirectoryIndex
    index.html index.htm index.php index.html.var”。
    7.设置日志文件
    日志文件对于用户查找系统故障或者分析Web服务器运行状况非常重要,此时有两项重要设置内容。
    (1)错误日志。错误日志记录了Apache在启动和运行时发生的错误,所以当Apache出错的时候,应该首先检查这个日志文件。通常错误日志的文件名为error_log,错误日志文件存放的位置和文件名可以通过ErrorLog参数进行设置。例如”ErrorLog
    logs/erroe_log”。如果日志文件存放路径不是以”/”开头,则表示该路径是相对于ServerRoot目录的相对路径。
    (2)访问日志。访问日志记录了客户端计算机所有的访问信息,通过分析访问日志可以知道客户机何时访问了网站的哪些文件等信息。通常访问日志的文件名为access_log,访问日志文件的存放位置和文件名可以通过CustomLog参数进行设置,例如”CustomLog
    logs/access_log combined”。
    在这个访问日志设置中,combined指明日志使用的格式,在这个位置可以使用common或者combined。其中common是指使用
    Web服务器普遍采用的普通标准格式,这种格式可以被许多日志分析程序所识别;combined是指使用组合记录格式,和common相比,combined的格式基本相同,只是多了引用页和浏览器识别信息而已。
    8.设置默认字符集
    AddDefaultCharset选项设置了服务器返回给客户端计算机的默认字符集,由于Apache服务器默认字符集为西欧(UTF-8),因此当客户端访问服务器的中文网页时会出现乱码现象。解决的办法是将语句”AddDefaultCharset
    UTF-8″改为”AddDefaultCharset
    GB2312″,然后重新启动Apache服务器,中文网页就可以正常显示了。
    (二)配置目录权限 1、定义目录特性
    Apache访问的每个目录可设置相关的服务和特性是允许或(和)不允许。(同样影响其子目录)
    首先,设置”default”地址只有最基本的权限:

2、配置文件
.htaccess
基于目录的配置文件,.htaccess文件包含对它所在目录中文件的访问控制指令
/etc/httpd/conf/httpd.conf Apache WEB服务器配置文件目录

复制代码 代码如下: