c# hash问题

2020-01-16 10:33栏目:竞技宝app
TAG:

要求把一段xml放入hash,设置hash10分钟过期,如果再有xml进来,和hash里存的xml比较,如果一样在跳出。请问怎么把xml写入Hash,并设置10分钟过期?

一、nginx

Nginx (发音同 engine x)是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。  其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页伺服器中表现较好。目前中国大陆使用nginx网站用户有:新浪、网易、 腾讯,另外知名的微网志Plurk也使用nginx。

废话不多说, 先上图...

图片 1

二、Tomcat

tomcat服务器就不用多说了吧。我们可以准备2、3个tomcat服务器进行测试。废话不多说,准备环境走起...

三、环境准备 

1、 jdk 1.8.0_102

2、nginx 1.12.0(在官网上下一个解压就行,官网:

3、2个或多个tomcat 6.x 7.x 8.x 9.x 都可以(比如我准备的是3个一模一样的8.x版本,只是配置文件改了而已,一会会详细怎么改 ,官网:

四、nginx配置文件

路径:nginx-1.12.0confnginx.conf

配置如下:



 [html]
 view plain copy

 

  1. #Nginx所用用户和组,window下不指定

    #user  niumd niumd;

    #工作的子进程数量(通常等于CPU数量或者2倍于CPU)

    worker_processes  2;

    #错误日志存放路径

    #error_log  logs/error.log;

    #error_log  logs/error.log  notice;

    error_log  logs/error.log  info;

    #指定pid存放文件

    #pid        logs/nginx.pid;

     

    events {

    #使用网络IO模型linux建议epoll,FreeBSD建议采用kqueue,window下不指定。

    #use epoll;

    #允许最大连接数

    worker_connections  2048;

    }

     

    http {

    include       mime.types;

    default_type  application/octet-stream;

    #定义日志格式

    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  off;

     

    access_log  logs/access.log;

     

    client_header_timeout  3m;

    client_body_timeout    3m;

    send_timeout           3m;

    client_header_buffer_size    1k;

    large_client_header_buffers  4 4k;

    sendfile        on;

    tcp_nopush      on;

    tcp_nodelay     on;

    #keepalive_timeout  75 20;

    #include    gzip.conf;

     

    #负载均衡配置

    upstream localhost {

    #根据ip计算将请求分配各那个后端tomcat,许多人误认为可以解决session问题,其实并不能。

    #同一机器在多网情况下,路由切换,ip可能不同

    #ip_hash;

    #upstream的负载均衡,weight是权重,可以根据机器配置定义权重。weigth参数表示权值,权值越高被分配到的几率越大。

    ip_hash;

    server localhost:18081;

    server localhost:18082;

    server localhost:18083;

     

    #nginx的upstream目前支持4种方式的分配

            #1、轮询(默认)

            #每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

            #2、weight

            #指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

            #例如:

            #upstream bakend {

            #    server 192.168.0.14 weight=10;

            #    server 192.168.0.15 weight=10;

            #}

            #2、ip_hash

            #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

            #例如:

            #upstream bakend {

            #    ip_hash;

            #    server 192.168.0.14:88;

            #    server 192.168.0.15:80;

            #}

            #3、fair(第三方)

            #按后端服务器的响应时间来分配请求,响应时间短的优先分配。

            #upstream backend {

            #    server server1;

            #    server server2;

            #    fair;

            #}

            #4、url_hash(第三方)

            #按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

            #例:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法

            #upstream backend {

            #    server squid1:3128;

            #    server squid2:3128;

            #    hash $request_uri;

            #    hash_method crc32;

            #}

     

            #tips:

            #upstream bakend{#定义负载均衡设备的Ip及设备状态}{

            #    ip_hash;

            #    server 127.0.0.1:9090 down;

            #    server 127.0.0.1:8080 weight=2;

            #    server 127.0.0.1:6060;

            #    server 127.0.0.1:7070 backup;

            #}

            #在需要使用负载均衡的server中增加 proxy_pass ;

     

            #每个设备的状态设置为:

            #1.down表示单前的server暂时不参与负载

            #2.weight为weight越大,负载的权重就越大。

            #3.max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream模块定义的错误

            #4.fail_timeout:max_fails次失败后,暂停的时间。

            #5.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

     

            #nginx支持同时设置多组的负载均衡,用来给不用的server来使用。

            #client_body_in_file_only设置为On 可以讲client post过来的数据记录到文件中用来做debug

            #client_body_temp_path设置记录文件的目录 可以设置最多3层目录

            #location对URL进行匹配.可以进行重定向或者进行新的代理 负载均衡

    }

    server {

    listen       80;

    server_name  localhost;

    location / {

    proxy_connect_timeout   3;

    proxy_send_timeout      30;

    proxy_read_timeout      30;

    proxy_pass ;

    }

     

    #css|js|ico|gif|jpg|jpeg|png|txt|html|htm|xml|swf|wav这些都是静态文件,但应分辨,js、css可能经常会变,过期时间应小一些,图片、html基本不变,过期时间可以设长一些

            location ~* ^.+.(ico|gif|jpg|jpeg|png|html|htm)$ {

                root         html;

                access_log   logs/access.log;

                expires      -1s;

            }

     

    gzip on;

            gzip_comp_level 7;

            gzip_min_length  1100; #需要压缩的最小长度

            gzip_buffers    4 8k;

            gzip_types      text/plain application/javascript text/css text/xml application/x-httpd-php; #指定需要压缩的文件类型

            output_buffers  1 32k;

            postpone_output  1460;

     

            #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;

            }

    }

    }

  2.  


 

五、Tomcat配置文件

apache-tomcat-8.5.16.1confserver.xml

... 

 <Server port="18006" shutdown="SHUTDOWN">

...

<Connector port="18081" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 

...

<Connector port="18009" protocol="AJP/1.3" redirectPort="8443" /> 

 ...

 

 apache-tomcat-8.5.16.2confserver.xml

 ...

<Server port="18007" shutdown="SHUTDOWN"> 

 ...

<Connector port="18082" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 

...

<Connector port="28009" protocol="AJP/1.3" redirectPort="8443" /> 

...

 

apache-tomcat-8.5.16.3confserver.xml

 ...

<Server port="18008" shutdown="SHUTDOWN"> 

...

<Connector port="18083" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 

 ...

 <Connector port="38009" protocol="AJP/1.3" redirectPort="8443" />

...

版权声明:本文由龙竞技官网发布于竞技宝app,转载请注明出处:c# hash问题