Linux配置nginx图片服务器+ftp服务器

         由于要实现图片上传,且服务器都要用阿里云的,Jboss也在Linux系统上,就采用了Nginx和FTP(也可采用nginx+NFS)。

        本篇博客主要介绍搭建Nginx和FTP的基本过程,部分简单且过细步骤从略,众亲自行百度即可。

        1、搭建Nginx

       (1)下载安装包,安装,Linux下安装nginx,需要先安装Gcc编译器、PCRE库、zlib库、OpenSSL开发库。然后再安装nginx。我用的Nginx-1.7.4版本,具体安装过程百度一下吧~

       (2)启动命令:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf。 /usr/local/nginx/sbin/nginx是你nginx的安装目录;nginx.conf是配置文件。

         注意:要确定系统的80端口是否被占用,如果被占用,可用vi命令修改nginx.conf,具体修改方法见下面的配置文件。

 

     检查是否启动成功:ps -ef | grep nginx。

     如果成功了,看看在浏览器中输入http://127.0.0.1 是否访问到了Nginx欢迎界面?访问到就恭喜你安装成功了!


    (3)下面是如何配置nginx.conf,使其成为图片服务器。

     

user  root;
worker_processes  1;
worker_rlimit_nofile 65535;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  12040;
}


http {
    include       mime.types;
    default_type  application/octet-stream;
	#Proxy_cache_path    /usr/local/nginx/NginxTestImgLog levels=1:2  keys_zone=cache_one:200m inactive=1d max_size=30g;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       8088;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
			#proxy_pass http://192.168.10.223:1234;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
server {
        listen       7788;
        server_name  localhost;
	#    ssl on;
    #    ssl_certificate      /usr/local/nginx/conf/server.crt;
    #    ssl_certificate_key  /usr/local/nginx/conf/server_nopwd.key;

	charset utf-8;
	#charset koi8-r;
	
	location ~ (\.jsp)|(\.do)/ {
		proxy_pass http://127.0.0.1:7001;
		proxy_set_header X-Real-IP $remote_addr;
		
		proxy_set_header Host $host;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
		proxy_buffer_size 4k;
		proxy_buffers 4 32k;
		proxy_busy_buffers_size 64k;
		proxy_temp_file_write_size 64k;
		proxy_max_temp_file_size 512m;
      }
    }
	
	server {
			listen 8888;
			server_name localhost;
		
		charset utf-8;
		
			location ~ .*\.(gif|jpg|jpeg|png){
				#allow 127.0.0.1;
				#deny all;
				
				#expires 24h;
					root /usr/local/nginx/nginxTestImg/;
					access_log /usr/local/nginx/NginxTestImgLog/log_test.log;
					proxy_store on;
					proxy_store_access user:rw group:rw all:rw;
					
					proxy_redirect    off;
					
					proxy_set_header  Host $host;
					proxy_set_header  X-Real-IP $remote_addr;
					proxy_set_header  X-Forwarded-For $remote_addr;
					client_max_body_size       10m;
					client_body_buffer_size    1280k;
					proxy_connect_timeout      900;
					proxy_send_timeout         900;
					proxy_read_timeout         900;
					proxy_buffer_size          1024k;
					proxy_buffers              40 1024k;
					proxy_busy_buffers_size    1024k;
					proxy_temp_file_write_size 1024k;
				proxy_temp_path    /usr/local/nginx/nginxTestImg/;
				#Proxy_cache_path /nginxTestImg/;
				if ( !-e $request_filename)
					{
				proxy_pass http://127.0.0.1:8888;
					}
					
			}
			location / {
				root html;
				index index.html index.htm;
			}
			
			#error_page 404   /404.html;
			# redirect server error pages to the static page /50x.html
			#
			error_page   500 502 503 504  /50x.html;
			location = /50x.html {
				root   html;
			}
			
		
	}

}

       

          配置完后,执行reload命令重新加载配置文件。然后放入一张图片(如,cat.jpg)后进行访问http://127.0.0.1:8888/cat.jpg ,如果能访问,说明搭建成功。



         2、搭建FTP服务器

       (1)安装,使用yum命令在Linux上安装即可

       (2)启动ftp服务 cd /ect/vsftpd(ftp的安装目录)   换行,./vsftpd.conf 或者service vsftpd restart(通用)

       (3)之后比较关键的是修改配置文件:

         首先,新建一个用户,如apple,并为其设置密码

# useradd -d /etc/vsftpd/apple apple //增加用户apple,并制定test用户的主目录为/etc/vsftpd/apple
# passwd apple//为test设置密码
            然后,把apple加到/etc/vsftpd/user_list文件中;如果该文件的同级文件vsftpd.chroot_list和ftpusers中含有你注册的用户名,要将其在这两个文件中注掉。

         重启ftp服务,命令见(2),就OK啦。

         还有一点要注意的是,如果使用ftp过程总是说无权限,要看看是否你的vsftpd里的文件有读写权限,设置属性即可。

         之后,在你的apple文件夹下放一个cat.jpg文件,在浏览器中输入http://xxx.xxx.xxx.xxx/8888/apple/cat.jpg,看看是否看到了你的图片?




  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 25
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值