如何理解varnish
admin
2023-03-24 02:40:37
0
varnishi由management(主进程)和(child/cache)子进程组成
varnishi由management(主进程)和(child/cache)子进程组成
	management的工作:
		1、提供命令行接口
		2、监控和管理子进程,初始化varnish
		3、将default.vcl编译为二进制生成新的配置文件
		
	child/cache的工作:
		1、接收连接请求
		2、处理用户请求
		3、清除缓存中的过期对象
		4、记录日志
		5、根据default.vcl生成缓存策略

			
	VCL:
		1、缓存策略配置接口
		2、基于"域"的配置
	
	存储缓存对象:
	    flie:单个文件进行存储,不支持持久化,会产生大量磁盘i/o对性能有一定影响
            malloc:内存存储,性能较高,代价更高(内存比磁盘贵),长时间使用会产生内存碎片
	    persistent:单个文件进行存储,支持持久化,目前作为测试使用
	
	varnish安装:centos7环境
		1、配置epel源
		2、yum -y install varnish

	
	varnish配置:
		/etc/varnish/default.vcl	#vcl配置文件
		/etc/varnish/varnish.params	#命令行参数配置文件
		/etc/varnish/secret		#连接命令行认证文件
		
	
	varnish管理工具:
		systemctl start varnish.service		#启动varnish
		varnish默认监听*:6081和127.0.0.1:6082,6081提供服务,6082提供管理
		
		varnishadm			#交互式命令行管理工具
		varnishlog			#交互式获取日志工具
		varnishncsa			#交互式获取日志工具(apache格式)
		varnishstat			#显示状态
		varnishtop			#排序


	varnish.params详解:
		VARNISH_VCL_CONF=/etc/varnish/default.vcl	#指定vcl文件位置
		VARNISH_LISTEN_PORT=6081	#指定服务端口,默认监听所有地址
		VARNISH_ADMIN_LISTEN_ADDRESS=127.0.0.1		#管理ip
		VARNISH_ADMIN_LISTEN_PORT=6082			#监听端口
		VARNISH_SECRET_FILE=/etc/varnish/secret		#认证文件
		VARNISH_STORAGE="file,/var/lib/varnish/varnish_storage.bin,1G" 
		    #缓存方式(单个文件缓存)		
		#VARNISH_STORAGE="malloc,256M"	    #缓存方式(内存缓存),不能同时启动
		VARNISH_USER=varnish			#程序用户
		VARNISH_GROUP=varnish			#程序组
#DAEMON_OPTS="-p thread_pool_min=5 -p thread_pool_max=500 -p thread_pool_timeout=300"	#进程池配置
		
		
    varnish状态引擎详解:状态引擎用于对客户端请求进行判断并作出相应处理
	vcl_recv:接收用户请求,判断如何处理
	vcl_pass: 绕过缓存,不从缓存中查询内容,将请求直接传递给后端主机
	vcl_pipe:无法解析请求类型,直接交给后端处理
		
	vcl_hash:可缓存数据,通过hash进行处理
        vcl_hit:缓存命中    
	vcl_deliver:将缓存数据返回给客户端
			
	vcl_miss:缓存未命中          
	vcl_fetch:从后端主机获取内容,通过判断将内容放入缓存或,直接返回给客户端
			
	vcl_error:如果请求出现错误,由varnishi构建错误页返回给客户端

		
	varnish负载均衡集群算法:		
		random         #随机
		round-robin    	#轮询
		fallback		#备份
		hash			#固定后端
		
		
配置实例:
    vcl 4.0;			#varnish版本
    probe cache {		#定义健康检查函数
    .url = "/index.html";	#检查的url  			  
    .timeout = 1s;		#超时时间
    .interval = 5s;  		#重试间隔
    .window = 5;    		#重试次数
    .threshold = 3;		#重试三次成功则认为服务器在线
    }

    backend www1 {			#定义后端主机
        .host = "192.168.0.10";		#后端主机
        .port = "80";			#监听端口
        .probe = cache;			#调用健康检查函数
    }


    backend www2 {
    	.host = "192.168.0.40";
	.port = "80";
	.probe = cache;
    }


    backend www3 {
	.host = "192.168.0.70";
	.port = "80";
	.probe = cache;
    }


    import directors; 				#导入集群模块
    sub vcl_init {
	new www = directors.round_robin();	#使用轮询算法
            www.add_backend(www1);	#集群主机
	    www.add_backend(www2);	#集群主机
	    www.add_backend(www3);	#集群主机
	}

    sub vcl_recv {			
	set req.backend_hint = www.backend();		#将所有流量发送给www集群
    }		
	
		
		
		
		
		

相关内容

热门资讯

【今日要闻】“普通扑克雷达感应... 网上科普关于“普通扑克雷达感应分析仪有没有挂”话题很是火热,小编也是针对普通扑克雷达感应分析仪作*弊...
玩家最新攻略“赫麒众游开挂神器... 网上科普关于“赫麒众游有没有挂”话题很是火热,小编也是针对赫麒众游作*弊开挂的方法以及开挂对应的知识...
国家网信办:人工智能拟人化互动... 为了促进人工智能拟人化互动服务健康发展和规范应用,依据《中华人民共和国民法典》《中华人民共和国网络安...
终于明白“锦绣山河是不是有挂?... 网上科普关于“锦绣山河有没有挂”话题很是火热,小编也是针对锦绣山河作*弊开挂的方法以及开挂对应的知识...
避坑云手机哪个好用性价比高 2... "2025年社畜福音!实测5款云手机,博奥云手机竟每天白送3小时!手把手教你选性价比之王,低配机也能...
我来教教您“AAPOKER开挂... 家人们!今天小编来为大家解答AAPOKER透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...
【第一财经】“哥哥斗地主开挂器... 有 亲,根据资深记者爆料哥哥斗地主是可以开挂的,确实有挂(咨询软件无需打...
今日重磅消息“毛豆炸/金/花开... 家人们!今天小编来为大家解答毛豆炸/金/花透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...
【第一财经】“科乐填大坑真的有... 网上科普关于“科乐填大坑有没有挂”话题很是火热,小编也是针对科乐填大坑作*弊开挂的方法以及开挂对应的...
终于懂了“个旧麻将辅助器?”(... 终于懂了“个旧麻将辅助器?”(必胜开挂神器)您好,个旧麻将这个游戏其实有挂的,确实是有挂的,需要了解...