安装日志采集服务器nginx

在Ubuntu上进行日志服务器的安装

我使用的环境是64位 Ubuntu 14.04。nginx依赖以下模块:

  • gzip模块需要 zlib 库
  • rewrite模块需要 pcre 库
  • ssl 功能需要openssl库

1.1.安装pcre

  1. 获取pcre编译安装包,在http://www.pcre.org/上可以获取当前最新的版本
  2. 解压缩pcre-xx.tar.gz包。
  3. 进入解压缩目录,执行./configure。
  4. make & make install
  5. 获取openssl编译安装包,在http://www.openssl.org/source/上可以获取当前最新的版本。
  6. 解压缩openssl-xx.tar.gz包。
  7. 进入解压缩目录,执行./config。
  8. make & make install
  9. 获取zlib编译安装包,在http://www.zlib.net/上可以获取当前最新的版本。
  10. 解压缩openssl-xx.tar.gz包。
  11. 进入解压缩目录,执行./configure。
  12. make & make install
  13. 获取nginx,在http://nginx.org/en/download.html上可以获取当前最新的版本。
  14. 解压缩nginx-xx.tar.gz包。
  15. 进入解压缩目录,执行./configure
  16. make & make install

1.2.安装openssl

1.3.安装zlib

1.4.安装nginx

若安装时找不到上述依赖模块,使用--with-openssl=<openssl_dir>、--with-pcre=<pcre_dir>、--with-zlib=<zlib_dir>指定依赖的模块目录。如已安装过,此处的路径为安装目录;若未安装,则此路径为编译安装包路径,nginx将执行模块的默认编译安装。

启动nginx之后,浏览器中输入http://localhost可以验证是否安装启动成功。

cd /usr/local/nginx中使用sbin/nginx启动nginx,这样在进行检测

启动成功

在浏览器中进行检测

1.5进行nginx的配置

cd /usr/local/nginx/cong/nginx.conf            进行 nginx的配置,例如

worker_processes  2;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    log_format tick "$msec^A$remote_addr^A$u_domain^A$u_url^A$u_title^A$u_referrer^A$u_sh^A$u_sw^A$u_cd^A$u_lang^A$http_user_agent^A$u_utrace^A$u_account";
    
    access_log  logs/access.log  tick;

    sendfile        on;

    keepalive_timeout  65;

    server {
        listen       80;
        server_name  localhost;
		location /log.gif {
			#伪装成gif文件
			default_type image/gif;    
			#本身关闭access_log,通过subrequest记录log
			access_log off;
		
			access_by_lua "
				-- 用户跟踪cookie名为__utrace
				local uid = ngx.var.cookie___utrace        
				if not uid then
					-- 如果没有则生成一个跟踪cookie,算法为md5(时间戳+IP+客户端信息)
					uid = ngx.md5(ngx.now() .. ngx.var.remote_addr .. ngx.var.http_user_agent)
				end 
				ngx.header['Set-Cookie'] = {'__utrace=' .. uid .. '; path=/'}
				if ngx.var.arg_domain then
				-- 通过subrequest到/i-log记录日志,将参数和用户跟踪cookie带过去
					ngx.location.capture('/i-log?' .. ngx.var.args .. '&utrace=' .. uid)
				end 
			";  
		
			#此请求不缓存
			add_header Expires "Fri, 01 Jan 1980 00:00:00 GMT";
			add_header Pragma "no-cache";
			add_header Cache-Control "no-cache, max-age=0, must-revalidate";
		
			#返回一个1×1的空gif图片
			empty_gif;
		}   
	
		location /i-log {
			#内部location,不允许外部直接访问
			internal;
		
			#设置变量,注意需要unescape
			set_unescape_uri $u_domain $arg_domain;
			set_unescape_uri $u_url $arg_url;
			set_unescape_uri $u_title $arg_title;
			set_unescape_uri $u_referrer $arg_referrer;
			set_unescape_uri $u_sh $arg_sh;
			set_unescape_uri $u_sw $arg_sw;
			set_unescape_uri $u_cd $arg_cd;
			set_unescape_uri $u_lang $arg_lang;
			set_unescape_uri $u_utrace $arg_utrace;
			set_unescape_uri $u_account $arg_account;
		
			#打开日志
			log_subrequest on;
			#记录日志到ma.log,实际应用中最好加buffer,格式为tick
			access_log /var/nginx_logs/ma.log tick;
		
			#输出空字符串
			echo '';
		}
    }
}
从新启动nginx






猜你喜欢

转载自blog.csdn.net/williamleejian/article/details/80502430