服务器软件的安装和配置
对于Windows下多数软件的安装,我们是通过执行该软件的安装程序(setupexe、installexe、软件文件名exe),由安装程序负责具体的安装过程。
这个过程中,安装程序做的工作一是系统注册:把该软件的一些系统文件,复制或移动到操作系统的有关系统目录中,实现与操作系统的接口,便于操作系统使用;二是将自身的程序文件、数据文件等复制到本软件的安装目录下,用于本软件的运行。
(1)PHP语言解释器软件的安装和配置
该软件没有安装程序,所以具体的安装过程需要用户来完成。不过过程也十分简单:解压缩该软件包至安装目的目录,将系统文件php4tsdll(PHP系统扩展函数库)和phpini(PHP配置文件)分别放到操作系统目录下的相应的位置即可。
(2)Apache的安装和配置
大体经过安装->配置两大步骤完成。配置大体经过编辑配置文件->启动服务完成。
安装:其安装过程由其安装程序进行,启动安装程序后,按提示操作即可。
配置目的:向Apache说明清楚PHP的有关情况,以便实现二者的协作。
配置方法:主要通过一个配置文件中有关参数的修改或添加进行。所谓“修改”,即对该文件中已经存在的参数,修改其参数值;所谓“添加”,即将该文件中缺少的参数和参数值增加到该文件中相应位置,为了省事,也可以放到该文件的最后。该文件名为httpdconf,存在于Apache安装目录下的conf目录下,是一个纯文本文件,可用记事本打开修改。也可以通过开始菜单中Apache程序组中的“Edit Configuration”打开该文件,进行配置操作。注意每次配置变动后一定要保存,并启动或重新启动Apache的服务,所做的最新配置才会起作用。
有关参数和参数值的说明
1)格式多是这样的单独的行:
#参数名 参数值 行首的#表示注释,应去掉才会使配置起作用。
2)参数和参数值的含义、作用
表2 Apache配置参数设定 示例路径:PHP安装路径——d:/php;发布文档(即文件)主目录——d:/www
参数名和参数值 操作 作用
① BindAddress 服务器机器IP 修改 进行地址绑定(指定服务器地址)
② LoadModule php4_module d:/php/sapi/php4apachedll 添加 指名将PHP配置为Apache的模块(Apache module)方式进行工作时的PHP语言解释器
③ Port 80 修改 指定Apache对外提供Web服务的通信端口
④ ServerAdmin 服务器管理员邮箱(如abc@abccom) 修改 当发生错误时送回客户端浏览器的管理员信箱
⑤ ServerName 服务器的计算机名称 修改 指明主机名称
⑥ DocumentRoot "d:\www" 修改 指明向客户端提供Web服务的发布文档主目录
⑦ 修改 发布文档主目录定义,该处目录的值应与⑥中的一致
⑧ ScriptAlias /php/ "d:/php/" AddType application/x-httpd-php php Action application/x-httpd-php "/php/phpexe" 添加 指明PHP脚本语言名称和PHP脚本语言解释器的路径 指明PHP脚本扩展名 指明PHP脚本解释器(PHP以非模块工作时起作用)
⑨ DirectoryIndex indexphp 修改 指定默认文档(主页文档,只请求服务器地址就响应的文档)
有关服务的操作:服务,是一直运行,监听来自其他程序(客户端)的请求,接收请求,处理请求(自己处理或提交其他程序处理),返回处理结果的一种运行着的程序,一种进程。一般运行于操作系统后台。
有关Apache的服务操作,通过开始菜单中Apache程序组中的有关命令进行:
′ Install Service:在操作系统中注册服务
′ Uninstall Service:在操作系统中删除服务
′ Start Service:启动服务
′ Restart Service:重新启动服务
′ Stop Service:停止服务
注意: 服务的`启动、重新启动、停止,必须以在操作系统中注册了服务为前提; 服务的启动、重新启动、停止过程中有Apache的消息反馈。
(3)Apache与PHP的协同测试
测试目的是检查二者是否能够正常协作。具体来说,是检验配置后的Apache、PHP、浏览器是否具备了这样的协作能力: 用户通过浏览器向服务器请求 PHP 文件(如在地址栏输入:http://2116440187/indexphp),Apache 在服务器上的用户文档发布目录下查找浏览器所请求的PHP文件,若找不到,则向浏览器返回错误信息,否则,将其提交给PHP解释器解释执行,PHP解释器对该PHP文件进行语法分析,若发现语法错误,则经Apache返回错误信息(以浏览器能识别的代码表示)到浏览器,否则执行该PHP程序(可能包含对数据库MySQL的操作),将PHP程序执行结果(以浏览器能识别的代码表示)经Apache返回到浏览器,浏览器对返回的结果进行解释、执行,执行的结果显示在浏览器窗口中。
做法是,在服务器上用户的发布文档目录下,放置一个含有 PHP 代码的文件,即 PHP 程序,通过客户端浏览器,向服务器请求这个文件,若浏览器能得到正确的来自服务器的结果,则表明二者安装和配置成功,否则,应根据出错信息,修改配置。
作一台代理服务器的前提条件
1、 首先有一台配置较好的计算机(如果要代理的客户机比较多,超过100台,那么最好买一台专用的服务器),并且保证这台计算机可以稳定的接入Internet。如果有2-5台客户时,可以采用拨号上网(56Kbps);如果用户比较多,那么就需要用DDN(64Kbps-2Mbps)、ISDN(128Kbps)、ADSL(8Mbps)、或者是宽带上网等方式。
2、 其次,这台机器最好配置两个网络适配器,所谓的网络适配器其实就是一台计算机和网络之间的一个连接界面(比如网卡就是一个网络适配器)。 所以,该机器要拥有两个IP地址,一个IP地址用来访问因特网,另一个IP地址用来让内部网中不能上网的客户机访问到代理服务器。注意:在这里为了保证内部网用户访问到代理服务器,内部网的客户机的IP地址和服务器的IP地址在同一个网络中。
3、 还要在机器上安装一个可以实现代理功能的工具,比如:ccproxy、伊特代理、sygate、wingate、winproxy、microsoft isa server等等。
4、 最后,因为代理服务器是连接内部网和外部网的一台机器,所以该机器上必须要做好抵抗一切不安全的攻击,拒绝一切非法的网络信息的流通。
telnet 你当前的公网IP 80
看是否能连接上,如果不能连接说明你公网IP的80端口没有映射到服务端口,关闭防火墙,包括你起WEB服务机器网卡上的筛选器也关掉,IIS里把服务捆绑在你内网IP上
第1步:安装一个服务我这装的是oneInstack
第2步:先在阿里云添加一个安全组50
第3步:ssh:在oneinstack 执行/vhostsh 这是添加虚拟机
第4步:在/usr/local/nginx/conf/vhost目录下 修改端口
第5步:web 服务开启 端口 iptables -A INPUT -p tcp --dport 50 -j ACCEPT
第6步:ssh:执行service nginx restart 重启服务
第7步:在/data/wwwroot/ip地址:50 放自己页面文件
完了,你可以在服务器ip后面加50就可以访问了,你还可以类似开启30,40,60之类的端口
nginx部署
1在下载的ngnix的工具中执行下面命令:
start /nginxexe回车即启动了nginx服务
2检查是否成功
输入http://localhost 会有Welcome to nginx!
3nginx配置
找到nginx下的conf/nginxconf文件,设置代理相关信息,重点是server{}中的内容
server {
listen 80;
server_name testcom;
# 这里是你要代理的测试环境域名加上-local
# 比如你的项目测试环境为testcom,你本地此处可以设置为testcom,当然你可以随便设置
location /{
add_header 'Access-Control-Allow-Origin' '';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'DNT,web-token,app-token,Authorization,Accept,Origin,Keep-Alive,User-Agent,X-Mx-ReqToken,X-Data-Type,X-Auth-Token,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
# 此处8091是我们本地运行项目的端口号,设置成跟你本地起的服务端口号一样就行
proxy_pass http://127001:8091/;
}
}
登录后复制

4本机dns配置
修改本地host文件配置
找到目录C:\Windows\System32\drivers\etc,打开hosts文件,修改文件,加入127001 testcom
然后在testcom 可以看到Welcome to nginx!
5运行
先输入/nginxexe -t检查nginx配置是否正确
继续输入nginx -s reload重启(nginx配置文件修改后都要重启nginx才会生效)
刷新dns: ipconfig /flushdns
ngnix设置一个服务
root就是文件的 地址 localhost:8000/文件名后缀 就是页面地址
server {
listen 8000;
# listen somename:8080;
# server_name somename alias anotheralias;
location / {
root "E:\华侨城\西安欢乐谷\聚合-集成小程序\src\pages\index";
index indexhtml indexhtm;
}
}
登录后复制

本地通过http-server启动服务
npm install http-server -g
http-server -p 8881
页面输入127001:8881 然后写入页面aaahtml 就可以访问了
登录后复制
重启redis
1cmd打开redis目录:
redis-serverexe rediswindowsconf
每次重启 是不是很麻烦,自动启动的方法:
1在redis目录启动redis: redis-serverexe rediswindowsconf
2在redis设置用户名密码:
redis-cliexe
然后输入 set name wangjigen 设置自己的名字 getname 看看自己是否设置成功
config set requirepass wjg720941设置密码 auth 需要输入自己的密码
config get requirepass 查看自己的用户名密码
3设置服务命令
redis-server --service-install rediswindows-servi` ceconf --loglevel verbose
然后在计算机服务点击可开启
over
然而启动的时候会报错
node_redis: Warning: Redis server does not require a password, but a password was supplied
1可能是这是redis程序没有指向windowconf 文件 redis-serverexe rediswindowsconf
2可能是或者在 rediswindowsconf文件搜索requirepass 添加密码 requirepass asd123
目前FastDFS支持类Unix系统 ,在Linux和FreeBSD下测试过,本文使用的是Ubuntu104,建议安装之前先简单了解一下FastDFS的原理 ,这对后继的配置部分会有很好的理解。
一、准备工作-安装libevent
FastDFS 内部绑定了 libevent 作为 http 服务器 ,在V2X版本必须安装 libevent ,本文安装的是V22版本,因此必须安装libevent。(官方也推荐使用 http 方式下载 文件 )
如果已经安装了 libevent,请确认安装路径是 /usr , 因为 FastDFS 在编译源程序时,需要到此目录下查找一些依赖文件,否则编译 FastDFS 会出错 。如果不是,建议首先卸载 libevent ,然后安装到 /usr 下。Ubuntu104默认是安装了libevent,可以到软件中心卸载掉然后按照下面介绍的方式安装。
安装步骤:
解压 libevent ,然后进入解压后的目录分别执行:
Shell代码
/configure --prefix=/usr
make clean;
make
make install
安装libevent完成。
二、安装 FastDFS
1、下载 FastDFS 源程序
2、在 FastDFS_v405targz 所在文件夹下执行:
Shell代码
sudo tar vxzf FastDFS_v405targz /home/soar/FastDFS
注: /home/soar/FastDFS 也可以是其他目录,记住这是解压目录,以后用 %FastDFS% 表示)
3、由于要使用内置的 http 服务,因此编辑 %FastDFS%/makesh 文件,找到
#WITH_HTTPD=1
修改成
WITH_HTTPD=1
以支持 http
4、进入 %FastDFS% 目录,执行:
Shell代码
sudo /makesh
5、在 %FastDFS% 目录下,执行:
Shell代码
sudo /makesh install
如果运行如上命令后,在命令行信息最后看到类似
Shell代码
#ln -fs /usr/local/lib/libfastcommonso1 /usr/local/lib/libfastcommonso
#ln -fs /usr/local/lib/libfdfsclientso1 /usr/local/lib/libfdfsclientso
sh /fdfs_link_librarysh
恭喜你,已经安装成功了!
FastDFS的配置文件在%FastDFS%/conf目录下,其中包括
Clientconf 客户端上传配置文件
Storageconf 文件存储服务器配置文件
Trackerconf 负责均衡调度服务器配置文件
httpconf http服务器配置文件
配置文件需要根据服务器环境的不同,进行不同的配置,具体可以参考FastDFS官方的安装配置文档,以及FastDFS原理介绍文档
在本例中,Tracker Server,Storage Server都安装在一台服务器上,IP:100215
1、配置及启动Tracker Server
A、修改%FastDFS%/conf/trackerconf文件,修改如下
#可以自己指定目录位置,但目录必须存在,用于存储日志及storage server等信息,否则tracker server无法启动
Txt代码
base_path=/home/yuqing/fastdfs -> base_path=/home/soar/fastdfs_tracker
#改成你想要的http端口,将来http下载文件的端口就是他了
Txt代码
httpserver_port=8080 -> httpserver_port=8090
#http支持
Txt代码
##include httpconf -> #include httpconf
#默认4GB,如果空间不足,建议调小,否则会报no free space的异常,无法正常启动
Txt代码
reserved_storage_space = 4GB -> reserved_storage_space = 1GB
#tracker server对storage server供服务的端口,使用默认的即可,也可以自定义
Txt代码
port=22122
B、将httpconf文件拷贝到/etc/fdfs目录下,执行
Shell代码
sudo cp %FastDFS%/conf/httpconf /etc/fdfs/
注:为了支持http,必须将这个文件拷贝到此目录,否则无法启动,报param httpXXX not exist or is empty类似的错误
C、进入/usr/local/bin/目录,启动tracker服务器,执行
Shell代码
sudo fdfs_trackerd %FastDFS%/conf/trackerconf
D、进入/home/soar/fastdfs_tracker/logs/trackerdlog查看tracker的启动日志,如果看到类似
Shell代码
[2010-11-04 16:21:25] INFO - FastDFS v202, base_path=/home/soar/fastdfs_tracker, connect_timeout=30s, network_timeout=60s, port=22122, bind_addr=, max_connections=256, work_threads=4, store_lookup=2, store_group=, store_server=0, store_path=0, reserved_storage_space=4MB, download_server=0, allow_ip_count=-1, sync_log_buff_interval=10s, check_active_interval=120s, thread_stack_size=64 KB, storage_ip_changed_auto_adjust=1, storage_sync_file_max_delay=86400s, storage_sync_file_max_time=300s
[2010-11-04 16:21:25] INFO - HTTP supported: server_port=8090, default_content_type=application/octet-stream, anti_steal_token=0, token_ttl=0s, anti_steal_secret_key length=0, token_check_fail content_type=, token_check_fail buff length=0, check_active_interval=30, check_active_type=tcp, check_active_uri=/statushtml
恭喜你,tracker server已经启动成功!
2、配置及启动Storage Server
A、修改%FastDFS%/conf/storageconf文件,修改如下:
#可以自定义,但必须存在此目录,用于存储storage相关的log、group内的相关信息
Txt代码
base_path=/home/yuqing/fastdfs -> /home/soar/fastdfs_storge
#文件的存储位置,在一台storage server上可以指定多个存储位置
Txt代码
store_path0=/home/yuqing/fastdfs -> store_path0=/home/soar/fastdfs_storge
#必须指定
Txt代码
group_name=group1
#修改成tracker server的IP和端口信息
Txt代码
tracker_server=192168209121:22122 -> tracker_server=100215:22122
#http支持
Txt代码
##include httpconf ->#include httpconf
B、进入/usr/local/bin/目录,启动storage服务器,执行
Shell代码
sudo fdfs_storaged %FastDFS%/conf/storageconf
C、进入/home/soar/fastdfs_tracker/logs/storagelog查看storage服务器启动日志,如果看到类似
Shell代码
[2010-11-04 16:37:16] INFO - FastDFS v202, base_path=/home/soar/fastdfs_storge, store_path_count=1, subdir_count_per_path=256, group_name=group1, connect_timeout=30s, network_timeout=60s, port=23000, bind_addr=, client_bind=1, max_connections=256, work_threads=4, disk_rw_separated=1, disk_reader_threads=1, disk_writer_threads=1, buff_size=256KB, heart_beat_interval=30s, stat_report_interval=60s, tracker_server_count=1, sync_wait_msec=200ms, sync_interval=0ms, sync_start_time=00:00, sync_end_time=23:59, write_mark_file_freq=500, allow_ip_count=-1, file_distribute_path_mode=0, file_distribute_rotate_count=100, fsync_after_written_bytes=0, sync_log_buff_interval=10s, sync_binlog_buff_interval=60s, sync_stat_file_interval=300s, thread_stack_size=512 KB, upload_priority=10, if_alias_prefix=, check_file_duplicate=0, FDHT group count=0, FDHT server count=0, FDHT key_namespace=, FDHT keep_alive=0, HTTP server port=8888, domain name=
[2010-11-04 16:37:16] INFO - HTTP supported: server_port=8888, http_trunk_size=262144, default_content_type=application/octet-stream, anti_steal_token=0, token_ttl=0s, anti_steal_secret_key length=0, token_check_fail content_type=, token_check_fail buff length=0
[2010-11-04 16:37:16] INFO - file: storage_param_getterc, line: 48, storage_ip_changed_auto_adjust=1
[2010-11-04 16:37:19] INFO - file: tracker_client_threadc, line: 274, successfully connect to tracker server 100215:22122, as a tracker client, my ip is 100215
恭喜你,storage server已经启动成功!
经过前面的安装、配置、启动,马上就可以看到FastDFS的效果了,我们先上传一个文件,然后再通过http下载。
一、上传文件
FastDFS安装包中,自带了客户端程序,通过程序可以进行文件上传。在使用这个客户端程序之前,首先需要配置clientconf,然后再进行文件上传及下载。
1、修改%FastDFS%/conf/clientconf文件,修改如下:
#可自定义,但此目录必须存在,用于存放文件上传log
Txt代码
base_path=/home/yuqing/fastdfs-> base_path=/home/soar/fastdfs_tracker
Txt代码
tracker_server=192168209121:22122 -> tracker_server=100215:22122
Txt代码
httptracker_server_port=8080 ->httptracker_server_port=8090
#支持http
Txt代码
##include httpconf ->#include httpconf
2、进入/usr/local/bin/目录,上传文件,执行
Txt代码
sudo fdfs_test %FastDFS%/conf/clientconf upload atxt
注:atxt可以在/usr/local/bin/目录下自己创建一个
如果命令行反馈类似如下:
则说明上传文件成功。
关于fastdfs集群和备份配置
1、修改trackerconf文件中store_lookup=2 平衡负载
2、修改trackerconf文件中store_server=0 采用轮询方式。
如果希望只使用一台文件存储服务器,其他二台做备份,则修改文件tracker_server为某台主机的IP,只启动文件存储服务器的tracker,其他二台备份服务器不需要启动tracker。
如果希望三台服务器集群使用,互相备份,比如:使用A机器存储文件,这时候A机器会将文件同步到B机器和C机器,同理使用B机器存储文件,则会同时将文件同步到A机器和C机器。这时候需要将所有的机器IP和端口号
都配置在storageconf中,如下所示:
tracker_server=1020716127:22122
tracker_server=1020716129:22122
1、安装ftp服务端,方便你从客户端上传文件。linux上一般安装vsftpVSFTP的软件安装包是: vsftpd-222-12el6_51i686rpm
查询:#rpm -q vsftpd
安装:#rpm -ivh vsftpd-222-12el6_51i686rpm或者直接yum install vsftpd
启动、停止及重启VSFTP的命令: #service vsftpd start/stop/restart
配置文件:
/etc/vsftpd/vsftpdconf //主配置文件
/etc/vsftpdftpusers //被禁止登录FTP的用户文件
/etc/vsftpduser_list //允许登录FTP的用户文件
a、将登录后的用户限制在本地家目录下:
#vi /etc/vsftpd/vsftpdconf
chroot_list_enable=YES
chroot_list_file=/etc/vsftpdchroot_list
新建受限用户的列表文件并加入受限用户名
#vi /etc/vsftpdchroot_list
raykeso
重启ftp服务
#service vsftpd restart
2、安装apache,开启目录索引,这样你就可以浏览和下载文件。
apache配置文件
<Directory "I:/build/dist"> #设置浏览文件的目录
Options Indexes #开启目录列表索引模式Order allow,deny
Allow from all
</Directory>
0条评论