admin
浏览(0) +
2005-09-04 22:06:38 发表
编辑
关键字:
不论水平多高总会用到别人写的程序,我在配置服务器过程中碰到了各种问题。这里写下我的解决方法,以便后来人。
admin
今天碰到了mysql的好几过问题。先说一个表损坏引起的问题,说实话我没想到mysql会有表损坏的事件。问题出在我们这个论坛程序访问时有时会有以下错误: “Query Error: SELECT tid,author,postdate,subject FROM pw_threads WHERE fid='4' ORDER BY lastpost DESC LIMIT 0,1 The URL Is: /bbs/mawhole.php? MySQL Server Error: Got error 134 from table handler ( 1030 ) You Can Get Help In: http://www.phpwind.net ” 重点是"MySQL Server Error: Got error 134 from table handler ( 1030 )"我按照几个关键字找到了 http://bugs.mysql.com/bug.php?id=1371 它的意思是让用户用repair命令修复表,我看了就不想改。后来一想phpMyAdmin也许就有这个功能,一看还真有,简单地点了两个按钮后就解决了。我的phpMyAdmin是2.2版本。
admin
还有一个问题是连接mysql的连接太多出错的问题,我在网上看到大多数网管/开发人员都碰到过。原因是mysql的并发数默认为100,这实在是太小了,不过要怎么修改呢?网上介绍说修改/etc/my.cnf,其实对于windo ws版本来说就是my.ini了。直接在管理 器中修改,然后点击save modi..按钮就可以了。 修改内容为: [mysqld] set-variable=max_connections=1500 set-variable=max_connect_errors=3000
admin
这好象仍然不是很够用,不过一般的网站是肯定不会有这么多并发数的了。
clq
Windows防火墙有缺陷 黑客隐藏打开端口 2005.09.02 来自:CNET科技资讯网 Windows Firewall中的一处缺陷可能使得用户无法看到Windows XP或Windows Server 2003 计算机上所有打开的 网络端口。 微软在本周三发布的安全公告中说,这一缺陷的原因在于Windows Firewall处理Windows 注册表中一些条目的方 式。注册表是Windows 注册表的核心部分,存储有PC的各项设置。 据微软称,该缺陷使得防火墙上的端口能够在不通过标准Windows Firewall用户界面通知用户的情况下被打开。 微软已经发布了一款补丁软件,用户可以从微软的网站上下载,该补丁软件也将是未来Windows 服务包的一部分 。 微软表示,该防火墙问题并非一个安全缺陷,但它说该缺陷能够被黑客用来隐藏打开的端口。 与其它防火墙软件一样,Windows Firewall能够过滤通向计算机的数据流量。通过创建一个异常项目,用户可以 允许流量通向计算机。Windows Firewall会在防火墙的用户界面中显示这些异常。 微软指出,通过使用其它工具,PC用户能够看到所有的防火墙异常。微软在安全公告中说,在命令行环境中输入 “netsh firewall show state verbose = ENABLE”就会显示所有处于活动状态的异常。
我是马甲
[apache]虚拟主机的例子 来自 http://www.uplinux.com/download/doc/apache/ApacheManual/vhosts/examples.html 本文档用于解释一些在设置虚拟主机时经常问及的问题。这些示例向你 展示了如何在一个服务器上通过基于域名 的或是基于IP的虚拟主机来部署多个 web站点。另一份关于如何在一个代理服务器后构建基于多个服务器的站点 的说明文档也很快就会出来。 在一个IP地址上运行多个基于域名的web站 点。 在多于一个IP的情况下使用基于域名的虚拟 主机。 在不同的IP的地址(比如一个内部和一个外部地址) 上提供相同的内容。 在不同的端口上运行不同的站点。 建立基于IP的虚拟主机 混用基于端口和基于IP的虚拟主机 混用基于域名和基于ip的虚拟主机 使用_default_虚拟主机 将一个基于域名的虚拟主机移植为一个基于 IP的虚拟主机 使用ServerPath指令 在一个IP地址上运行多个基于域名的web站 点。 您的服务器有一个IP地址,而在DNS中有很多映射(CNAMES)到这个机器。 您而您想要在这个机器上运行www.example1.com和 www.example2.org两个站点。 注意 在您Apache服务器的配置中创建一个虚拟主 机并不会自动在您的DNS中对主机名做相应更新。您必须自 己在DNS中添加域名来指向您的IP地址。否则别人是无法看到您的web 站点的。您可以在您的hosts文件中添加这一条目来进 行测试,但这种方法仅适用于那些有这些条目的机器来使用。 服务器配置 # Ensure that Apache listens on port 80 Listen 80 # Listen for virtual host requests on all IP addresses NameVirtualHost * DocumentRoot /www/example1 ServerName www.example1.com # Other directives here DocumentRoot /www/example2 ServerName www.example2.org # Other directives here 因为星号匹配所有的地址,所以主服务器不接收任何请求。因为 www.example1.com首先出现在配置文件中,所以它拥有最高 优先级,可以认为是默认或首要服务器。这意 味着如果一个接受的请求不能与某个ServerName指令相匹配, 它将会由第一个VirtualHost所伺服。 注意 如果您愿意,您可以用确定的IP地址来取代*。 在这种情况下,VirtualHost的参数必须 与NameVirtualHost的参数相符: NameVirtualHost 172.20.30.40 # etc ... 不论如何,当您的IP地址无法确定的时候,使用* 是很方便的——比如说,您的ISP给您配置的是动态IP地址,而您有 使用了某种动态域名解析系统时。因为*匹配任何IP 地址,所以在这样的情况下,不论IP地址如何变化,您都不需要另 外进行配置。 上述配置就是您在绝大多数情况下使用基于域名的虚拟主机时将要用到 的。事实上,仅在一种情况下这样的配置不会让您满意:当您想为不同的IP 地址或是端口提供不同的内容时。 在多于一个IP的情况下使用基于域名的虚拟 主机。 注意 在这里讨论的任何技术都可以推广到使用任意数量的IP 地址。 服务器有两个IP地址。一个(172.20.30.40)用于“主”服务器—— server.domain.com而另外一个 (172.20.30.50),我们将用于构建两个或多个虚拟主机。 服务器配置 Listen 80 # This is the "main" server running on 172.20.30.40 ServerName server.domain.com DocumentRoot /www/mainserver # This is the other address NameVirtualHost 172.20.30.50 DocumentRoot /www/example1 ServerName www.example1.com # Other directives here ... DocumentRoot /www/example2 ServerName www.example2.org # Other directives here ... 任何不是针对172.20.30.50的请求都将由主服务器来伺服。 而提交给172.20.30.50却没有主机名或没有 Host:头的请求,都将为www.example1.com伺 服。 在不同的IP的地址(比如一个内部和一个外部地址) 上提供相同的内容。 服务器有两个IP地址(192.168.1.1和 172.20.30.40)。这个机器位于内部(局域网)网络和外部 (广域网)之间。在外部,域名server.example.com指向 外部地址(172.20.30.40),而在内部,同样的域名指向内 部地址(192.168.1.1)。 服务器可以配置为向来自内部和外部的请求提供同样的内容,您只需要 一个VirtualHost配置段就可以达到这个目的。 服务器配置 NameVirtualHost 192.168.1.1 NameVirtualHost 172.20.30.40 DocumentRoot /www/server1 ServerName server.example.com ServerAlias server 现在,从不同的网络提交的请求都会由同一个 VirtualHost来伺服。 注意: 在内网中,您可以使用 server这个名字来代替 server.example.com全名。 跟上面一样,在上述的例子里,您可以用*来取代 具体的IP地址,这样就可以对所有的地址返回相同的内容了。 在不同的端口上运行不同的站点。 如果您想让同一IP的不同端口伺服多个域名。您可以借助在 “NameVirtualHost”标签中定义端口这样的方法来达到这个目的。如果您 想使用不带NameVirtualHost name:port的或是直接用Listen指令,您的配置将无法生效。 服务器配置 Listen 80 Listen 8080 NameVirtualHost 172.20.30.40:80 NameVirtualHost 172.20.30.40:8080 ServerName www.example1.com DocumentRoot /www/domain-80 ServerName www.example1.com DocumentRoot /www/domain-8080 ServerName www.example2.org DocumentRoot /www/otherdomain-80 ServerName www.example2.org DocumentRoot /www/otherdomain-8080 建立基于IP的虚拟主机 一个有两个IP地址(172.20.30.40和 172.20.30.50)分别对应域名 www.example1.com和www.example2.org的服务 配置如下: 服务器配置 Listen 80 DocumentRoot /www/example1 ServerName www.example1.com DocumentRoot /www/example2 ServerName www.example2.org 如果存在主服务器(main server),那么对没有出现在任一个 指令中的请求(比如,对 localhost的请求)都会由主服务器来伺服。 混用基于端口和基于IP的虚拟主机 如果您的服务器有两个IP地址(172.20.30.40和 172.20.30.50)分别对应域名 www.example1.com和www.example2.org。对每 个域名,您都希望在80端口和8080端口发布您的网站。您可以这样配置: 服务器配置 Listen 172.20.30.40:80 Listen 172.20.30.40:8080 Listen 172.20.30.50:80 Listen 172.20.30.50:8080 DocumentRoot /www/example1-80 ServerName www.example1.com DocumentRoot /www/example1-8080 ServerName www.example1.com DocumentRoot /www/example2-80 ServerName www.example1.org DocumentRoot /www/example2-8080 ServerName www.example2.org 混用基于域名和基于ip的虚拟主机 如果您想在一些地址上配置基于域名的虚拟主机而在另外一些配置基于 IP的虚拟主机。 服务器配置 Listen 80 NameVirtualHost 172.20.30.40 DocumentRoot /www/example1 ServerName www.example1.com DocumentRoot /www/example2 ServerName www.example2.org DocumentRoot /www/example3 ServerName www.example3.net # IP-based DocumentRoot /www/example4 ServerName www.example4.edu DocumentRoot /www/example5 ServerName www.example5.gov 使用_default_虚拟主机 为所有端口配置 _default_虚拟主机 这样配置,以捕获任何指向没指定的IP地址和端口的请求。比如 说:一个没被任何虚拟主机使用的地址/端口对。 服务器配置 DocumentRoot /www/default 使用这样一个使用通配符端口的默认虚拟主机可以有效的防止请求被主 服务器接收。 如果一个地址/端口对已经被一个基于域名的虚拟主机使用,那么默认虚 拟主机决不会处理发向这个地址/端口的请求。如果一个请求的 Host:头中包含未知信息,或者干脆就没有,那么它会被第一 个基于域名的虚拟主机(就是在配置文件中首先出现的使用了那个地址/端 口对的虚拟主机)处理。 您可以用AliasMatch或 RewriteRule来重写任何 请求,使它指向一个简单信息页面(a single information page)(或脚 本)。 为不同的端口部署 _default_虚拟主机 与第一种一样,但我们想让服务器侦听很多端口而第二个 _default_虚拟主机单独侦听80端口。 服务器配置 DocumentRoot /www/default80 # ... DocumentRoot /www/default # ... 侦听80端口的默认虚拟主机(必须出现在所有使用通配符端口 的虚拟主机之前)会捕获所有发向一个没有指定的IP地址的请求。主服务器 将不会用于伺服任何请求。 为一个端口配置 _default_虚拟主机 如果我们只想在80端口上建立唯一的一个默认虚拟主机,我们应该这样 配置: 服务器配置 DocumentRoot /www/default ... 发向一个未进行设定的地址的80端口的请求将会为这个虚拟主机伺服; 而发向未进行设定的地址的其他端口的请求为主服务器伺服。 将一个基于域名的虚拟主机移植为一个基于 IP的虚拟主机 如果一个具有www.example2.org域名的虚拟主机(就是基于域名配置示例中的第二个)得到了自己的IP地址。 为了避免一些域名服务器或代理服务器在移植期间仍对这个域名做老的解析, 我们可以采用一种过渡方法:同时提供新旧两个IP地址的解析。 达到这个目的很简单。因为我们只要简单的把新地址 (172.20.30.50)加入VirtualHost指令就行 了。 服务器配置 Listen 80 ServerName www.example1.com DocumentRoot /www/example1 NameVirtualHost 172.20.30.40 DocumentRoot /www/example2 ServerName www.example2.org # ... DocumentRoot /www/example3 ServerName www.example3.net ServerAlias *.example3.net # ... 现在这个虚拟主机就可以用新地址(表现为一个基于IP的虚拟主机)和 旧地址(表现为一个基于域名的虚拟主机)同时进行访问了。 使用ServerPath指令 如果我们在一个服务器上运行了两个基于域名的虚拟主机。为了匹配正 确的虚拟主机,客户端必须发送正确的Host:头。而旧的使用 HTTP/1.0的客户端无法发送这样的头,这样,Apache就无法辨别客户端想要 连接哪个虚拟主机(会用主虚拟主机来伺服这个请求)。为了尽量提供向下 兼容性,我们可以可以提供一个主虚拟主机来返回一个页面,在页面中加入 指向基于域名的虚拟主机的URL前缀的链接。 Server configuration NameVirtualHost 172.20.30.40 # primary vhost DocumentRoot /www/subdomain RewriteEngine On RewriteRule ^/.* /www/subdomain/index.html # ... DocumentRoot /www/subdomain/sub1 ServerName www.sub1.domain.tld ServerPath /sub1/ RewriteEngine On RewriteRule ^(/sub1/.*) /www/subdomain$1 # ... DocumentRoot /www/subdomain/sub2 ServerName www.sub2.domain.tld ServerPath /sub2/ RewriteEngine On RewriteRule ^(/sub2/.*) /www/subdomain$1 # ... 由于ServerPath指令的作用, 发送到http://www.sub1.domain.tld/sub1/的请求总会 被sub1-vhost所伺服。 如果客户端发送了正确的Host:头,发送到 http://www.sub1.domain.tld/的请求指挥被sub1-vhost伺服。 如果没有发送Host:头,客户端会得到从主虚拟主机发送的信 息页面。 请注意,这里还有一点小问题:如果客户端没有发送Host:头, 发送到http://www.sub2.domain.tld/sub1/的请求还是会被 sub1-vhost伺服。 RewriteRule指令用以确 保正确发送了Host:头的客户端可以任意使用这两种URL变量, 比如说:使用或不使用URL前缀。
clq
mysql 的中文排序问题 默认为 lant1 字符集的情况下中文排序是有问题的 有人说 出现这个问题的原因是:MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象 修改my.ini中 ,改字符集 [mysqld] default-character-set=gb2312 -------------------------------------------------- 但这样对已有的数据会造成乱码,我的做法时改字段为 binary ALTER TABLE `table1` CHANGE COLUMN `path1` `path1` binary(250) NULL; 或者在字段上加入 binary 属性 ALTER TABLE `table1` CHANGE COLUMN `path1` `path1` varchar(250)binary NULL;
NEWBT官方QQ群1: 276678893
可求档连环画,漫画;询问文本处理大师等软件使用技巧;求档softhub软件下载及使用技巧.
但不可"开车",严禁国家敏感话题,不可求档涉及版权的文档软件.
验证问题说明申请入群原因即可.