图片服务器搭建

1. 分析需求图片服务器的原因

在网站开发过程中使用tomcat集群时,可能存在在一个tomcat服务器中上传,在另外一个tomcat中进行访问,这样就会导致资源访问失败,而很好的解决这一问题的方法,就是搭建一个专门的服务器来实现文件的存储与读。

2. 搭建环境

Linux CentosOS6.3

Nginx

Vsftbd

FileZilla

3.安装http服务

3.1.安装Linux虚拟机

这个过程就不作详细讲解,翻阅网上资料,值得注意是在安装过程中,容易出现连不上,这就需要将网卡配置进行修改

         参考资料:

http://blog.chinaunix.net/uid-664509-id-291877.html //vi编辑文本命令

http://linux.chinaunix.net/techdoc/install/2009/07/21/1125434.shtml //网卡配置

3.2上传ngnix压缩文件文件到虚拟机

在上传本地文件到linux虚拟机上,可以采用xhell应用使用sftp会很方便

3.2.1 xshell建立普通会话

该会话只能就相当于可以直接在这里使用linux命令,而不需要进入虚拟机,这样会很方便  

3.2.2xshell建立sftp会话

Sftp只需要将协议修改即可,;而后直接进行登录

3.2.3上传文件

当上面会话建立完毕后,只需要将文件移动到sftp这个会话里面就能实现上传,操作如下:

而后可以在会话中判断该操作是否完成,下面显示结果可以判断是成功的

3.2.4文解解压

  文件解压命令 tar-zxvf nginx-1.8.0.tar.gz

使用解压命令后再次查询效果如下:

3.2.5配置makefile

Step1:打开解压后的ngnix目录,命令cdnginx-1.8.0,执行后并进行查看,发现目录结果如下

Step2:执行以下命令,生成makefile

上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录

生成后进入ngnix目录,执行复制以下参数进行执行(备注:没有gcc环境在~级别下安装命令:

yum -yinstall gcc automake autoconf libtool make

yum -y installgcc

./configure \

--prefix=/usr/local/nginx \

--pid-path=/var/run/nginx/nginx.pid \

--lock-path=/var/lock/nginx.lock \

--error-log-path=/var/log/nginx/error.log \

--http-log-path=/var/log/nginx/access.log \

--with-http_gzip_static_module \

--http-client-body-temp-path=/var/temp/nginx/client\

--http-proxy-temp-path=/var/temp/nginx/proxy\

--http-fastcgi-temp-path=/var/temp/nginx/fastcgi\

--http-uwsgi-temp-path=/var/temp/nginx/uwsgi\

--http-scgi-temp-path=/var/temp/nginx/scg

再次打开nginx目录生成一个makefile目录即表示配置成功

一些错误可以参考资料:

https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&tn=92297530_hao_pg&wd=the%20HTTP%20gzip%20module%20requires%20the%20zlib%20library.&oq=nginx%25E6%2597%25A0%25E6%25B3%2595make&rsv_pq=e495e51a00000827&rsv_t=37fcvNmXDaMLD%2FcuFCpqGiY0qkHBv%2Fy24Tlbo4l9%2BGuubeoI5nS9AFk2swmKV7nw3akVAc7T&rqlang=cn&rsv_enter=0&inputT=168709&rsv_sug3=390&bs=nginx%E6%97%A0%E6%B3%95make

https://zhidao.baidu.com/question/86868820.html

记得当某些错误问题解决后重新执行配置命令

3.2.6编译

nginx目录下 执行命令make 进行编译

  makeinstall 进行安装

3.2.7启动nginx

cd/usr/local/nginx/sbin/

./nginx

判断启动是否成功,直接在本机上访问ip是否看到nginx页面(端口80)

      不能访问,可能是防火墙的原因,参考资料

http://blog.csdn.net/lulen0724155075/article/details/51789164

3.2.8停止nginx

方式1,快速停止:

cd /usr/local/nginx/sbin

./nginx -s stop

此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

方式2,完整停止(建议使用):

cd /usr/local/nginx/sbin

. /nginx -s quit

此方式停止步骤是待nginx进程处理任务完毕进行停止。

3.2.9重启nginx

方式1,先停止再启动(建议使用):

对nginx进行重启相当于先停止nginx再启动nginx,即先执行停止命令再执行启动命令。

如下:

./nginx -s quit

./nginx

方式2,重新加载配置文件:

当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,使用-s reload不用先停止nginx再启动nginx即可将配置信息在nginx中生效,如下:

./nginx -s reload

4. 安装ftp服务器

既然存在资源被访问,就会存在资源上传,这就需要ftl服务器来进行,下面有安装ftl服务器的操作

3.1安装vsftpd组件

安装完后,有/etc/vsftpd/vsftpd.conf 文件,是vsftp的配置文件。

     [root@jackImage ~]# yum -y install vsftpd

3.2添加一个ftp用户

此用户就是用来登录ftp服务器用的。

[root@jackImage ~]# useradd ftpuser

这样一个用户建完,可以用这个登录,记得用普通登录不要用匿名了。登录后默认的路径为 /home/ftpuser.     

3.3给ftp用户添加密码

[root@jackImage ~]# passwd ftpuser

    输入两次密码后修改密码。

3.4防火墙开启21端口

因为ftp默认的端口为21,而centos默认是没有开启的,所以要修改iptables文件

[root@jackImage ~]# vim/etc/sysconfig/iptables

在行上面有22 -j ACCEPT 下面另起一行输入跟那行差不多的,只是把22换成21,然后:wq保存。

还要运行下,重启iptables

[root@jackImage ~]# service iptables restart

3.5修改selinux

外网是可以访问上去了,可是发现没法返回目录(使用ftp的主动模式,被动模式还是无法访问),也上传不了,因为selinux作怪了。

修改selinux:

执行以下命令查看状态:

[root@jackImage ~]# getsebool -a | grepftp 

allow_ftpd_anon_write --> off

allow_ftpd_full_access --> off

allow_ftpd_use_cifs --> off

allow_ftpd_use_nfs --> off

ftp_home_dir --> off

ftpd_connect_db --> off

ftpd_use_passive_mode --> off

httpd_enable_ftp_server --> off

tftp_anon_write --> off

[root@jackImage ~]#

执行上面命令,再返回的结果看到两行都是off,代表,没有开启外网的访问

[root@jackImage~]# setsebool -P allow_ftpd_full_access on

[root@jackImage~]# setsebool -P ftp_home_dir on

这样应该没问题了(如果,还是不行,看看是不是用了ftp客户端工具用了passive模式访问了,如提示Entering Passive mode,就代表是passive模式,默认是不行的,因为ftp passive模式被iptables挡住了,下面会讲怎么开启,如果懒得开的话,就看看你客户端ftp是否有port模式的选项,或者把passive模式的选项去掉。如果客户端还是不行,看看客户端上的主机的电脑是否开了防火墙,关吧)

FileZilla的主动、被动模式修改:

菜单:编辑→设置

3.6关闭匿名访问

修改/etc/vsftpd/vsftpd.conf文件:

重启ftp服务:

[root@jackImage ~]# service vsftpd restart

3.7设置开机启动vsftpd ftp服务

[root@jackImage ~]# chkconfig vsftpd on

3.8FileZilla登录ftp

5.文件上传及资源访问

5.1文件上传

文件上传不是麻烦,点击FileZilla右边的目录,在左边就可以实现上传

5.2资源访问

   在nginx.conf中指定资源访问路径,如下图所示,加一个Server

         指后可能还存在权限的问题,执行下方两句,即可

参考资料http://www.cnblogs.com/novalue/p/5751891.html

5.3测试结果

经过上述方法,图片服务器搭建成功,下面显示效果

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏lonelydawn的前端猿区

笔记本命令提示符开启wifi

首先win+r打开运行,输入cmd进入命令提示符 输入下列代码: netsh wlan set hostednetwork mode=allow ssid=wi...

1698
来自专栏deed博客

一个设置,改变网络设备体验

1157
来自专栏java相关

CentOS 7 防火墙设置

1103
来自专栏我爱编程

基于ubuntu搭建FTP文件服务

1636
来自专栏Java开发者杂谈

Redis(1):入门

在Linux下安装redis: wget http://download.redis.io/redis-stable.tar.gz tax xzf redi...

3088
来自专栏nummy

systemctl命令详解

systemctl命令是系统服务管理器指令,它实际上将 service 和 chkconfig 这两个命令组合到一起。

561
来自专栏帘卷西风的专栏

centos yum安装mysql5.6以上版本

centos 自带的软件库只能安装mysql5.1,后续的版本就不行了,要升级mysql只能自己想办法。

802
来自专栏IT笔记

Linux下使用ssh密钥实现无交互备份

服务器A(主) 192.168.1.120 服务器B(从) 192.168.1.130 需求:服务器B定期拉取服务器A的数据并备份。 实现方式: 一、备份服务器...

3276
来自专栏农夫安全

大家好,给大家介绍一下,这是linux运维安全之SSH安全

SSH一般用途 提供shell,解决telnet不安全的传输 1、修改默认ssh默认端口 vi /etc/ssh/sshd_config 修改之后重启 >sys...

3756
来自专栏北京马哥教育

想要创建一个基于TCP实现的http服务器,应该怎么做?

? 作者:Y-ANG 来源: http://blog.csdn.net/qq_33951180/article/details/70239745 我们先了解一...

48315

扫描关注云+社区