nginx+tomcat集群下的压力测试

我现在在单机下尝试模拟nginx+tomcat集群的配置,开了3台虚拟机,1台作nginx服务器另外两台作tomcat服务器。
tomcat下的也设置了maxThreads和timeOut的值。

nginx配的是将所有请求全部转发给后端的两台tomcat。

最后再装了nginx的虚拟机上用ab进行压力测试,在 -n 10000 -c 1500的时候
去测试192.168.171.134:18082没有问题,而测用127.0.0.1测nginx的时候则报错了。
apr_socket_recv: Connection timed out (110)

这个错误去查了说是修改sysctl.conf的参数,关于内核的优化我也去改过了,不过没用。按理说如果是这个问题的话,测192.168.171.134的时候同样是1500并发也应该报错的,但只有测nginx的时候才会报错,而且如果不用nginx的proxy_pass,单单测nginx下的html页面也不会报错。

还有比较奇怪的是,为什么配了nginx做负载均衡后无论用ab还是webbench测试得到的结果都是加上nginx后更慢呢而且还容易fail,我用的是tomcat的主页index.jsp作的测试页面

那么是不是我nginx哪里配的不对呢,我一时想不明白,有人能帮助我吗?

                     nginx.conf

user nobody;
worker_processes 2;
worker_rlimit_nofile 204800;

events {
use epoll;
worker_connections 204800;
}

http {
include mime.types;

default_type application/octet-stream;

fastcgi_intercept_errors on;

charset utf-8;

server_names_hash_bucket_size 128;

client_header_buffer_size 4k;

large_client_header_buffers 4 32k;

client_max_body_size 300m;

sendfile on;

tcp_nopush on;

keepalive_timeout 60;

tcp_nodelay on;

client_body_buffer_size 512k;

proxy_connect_timeout 5;

proxy_read_timeout 60;

proxy_send_timeout 5;

proxy_buffer_size 16k;

proxy_buffers 4 64k;

proxy_busy_buffers_size 128k;

proxy_temp_file_write_size 128k;

gzip on;

gzip_min_length 1k;

gzip_buffers 4 16k;

gzip_http_version 1.1;

gzip_comp_level 2;

gzip_types text/plain application/x-javascript text/css application/xml;

gzip_vary on;
upstream abc {

server 192.168.171.4:8080 weight=1 max_fails=2 fail_timeout=30s;

server 192.168.171.134:18082 weight=1 max_fails=2 fail_timeout=30s;

}

server {
listen 80;
server_name localhost;
large_client_header_buffers 4 16k;
client_max_body_size 300m;
client_body_buffer_size 128k;
proxy_connect_timeout 6000;
proxy_read_timeout 6000;
proxy_send_timeout 6000;
proxy_buffer_size 64k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;

    location /   {
    proxy_next_upstream http_502 http_504 http_404 error timeout invalid_header;

    proxy_pass http://abc; 
    }

}
}

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
nginx+tomcat集群下的压力测试
我现在在单机下尝试模拟nginx+tomcat集群的配置,开了3台虚拟机,1台作nginx服务器另外两台作tomcat服务器。 tomcat下的也设置了maxThreads和timeOut的值。 nginx配的是将所有请求全部转发给后端的两台tomcat。 最后再装了nginx的虚拟机上用ab进行压力测试,在 -n 10000 -c 1500的时候 去测试192.168.171.134:18082没有问题,而测用127.0.0.1测nginx的时候则报错了。 apr_socket_recv: Connection timed out (110) 这个错误去查了说是修改sysctl.conf的参数,关于内核的优化我也去改过了,不过没用。按理说如果是这个问题的话,测192.168.171.134的时候同样是1500并发也应该报错的,但只有测nginx的时候才会报错,而且如果不用nginx的proxy_pass,单单测nginx下的html页面也不会报错。 还有比较奇怪的是,为什么配了nginx做负载均衡后无论用ab还是webbench测试得到的结果都是加上nginx后更慢呢而且还容易fail,我用的是tomcat的主页index.jsp作的测试页面 那么是不是我nginx哪里配的不对呢,我一时想不明白,有人能帮助我吗? nginx.conf user nobody; worker_processes 2; worker_rlimit_nofile 204800; events { use epoll; worker_connections 204800; } http { include mime.types; default_type application/octet-stream; fastcgi_intercept_errors on; charset utf-8; server_names_hash_bucket_size 128; client_header_buffer_size 4k; large_client_header_buffers 4 32k; client_max_body_size 300m; sendfile on; tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; client_body_buffer_size 512k; proxy_connect_timeout 5; proxy_read_timeout 60; proxy_send_timeout 5; proxy_buffer_size 16k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; upstream abc { server 192.168.171.4:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.171.134:18082 weight=1 max_fails=2 fail_timeout=30s; } server { listen 80; server_name localhost; large_client_header_buffers 4 16k; client_max_body_size 300m; client_body_buffer_size 128k; proxy_connect_timeout 6000; proxy_read_timeout 6000; proxy_send_timeout 6000; proxy_buffer_size 64k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; location / { proxy_next_upstream http_502 http_504 http_404 error timeout invalid_header; proxy_pass http://abc; } } }
nginx+tomcat集群,如何保证数据一致性
在tomcat中,有一段代码,从redis里获取一个值,把这个值加1,重新存进去,这样在单例的情况下没有问题,但是部署到集群中就会导致数据不正确,比如tomcat1取出来为1,正打算加成2之后存进去,但是存进去之前tomcat2也取出来为1,这时候tomcat1存进去2,tomcat2加1后也存进去2,而事实上应该是3了
Tomcat集群+Nginx+Redis集群
看网上说用这个代码就行了,然后自己试了很久就是没有是成功过。(单个的Redis是没有问题的)多个就不行启动一直什么的1000ms....,还是我哪里没有设置对好,会的求教。 <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" maxInactiveInterval="60" sentinels="sentinel1-127.0.0.1:7000,sentinel2-127.0.0.1:7001,sentinel2-127.0.0.1:7002,sentinel3-127.0.0.1:7003, sentinel4-127.0.0.1:7004,sentinel5-127.0.0.1:7005,sentinel6-127.0.0.1:7006" />
nginx和tomcat做集群配置的时候还需要什么工具来辅助
虽然nginx和tomat可以做简单的集群配置,但这样做的实际开发中能用吗?
Nginx的tomcat集群使用Redis来共享session出现ClassNotFound
操作步骤 1、使用apache-tomcat-7.0.47-windows-x64 ,测试成功,可以打开8081 2、使用Redis-x64-3.2.100 安装成功,可以 ping get set 数据成功 3、然后下载了,commons-pool-1.5.4.jar,commons-pool2-2.4.1.jar,jedis-2.6.2.jar,tomcat-juli-adapters.jar,tomcat-redis-session-manager1.2.jar,tomcat-juli.jar 这6个jar包其中tomcat-juli.jar 和tomcat原来的tomcat-juli.jar 有冲突,一个大一点,一个小一点,估计里边的类不同。是否需要替换???我选择不替换。 4、然后在,tomcat的conf文件夹的context.xml配置文件添加 5、<!-- redis session 共享配置 --> <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" /> <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager" host="127.0.0.1" port="6379" database="0" maxInactiveInterval="60" /> </Context> 6、然后启动 tomcat,然后就报错了。 报错,ClassNotFoundException 找不到, com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve 没理由呀,RedisSessionHandlerValve在tomcat-redis-session-manager1.2.jar包里边,解压出来,在里边。路径也是一样的。 请问谁遇到了这样的情况??可以分享一下吗??
求助:nginx反向代理tomcat集群问题
1.我在Vmvare中安装了centos7,并且在centos7中安装了tomcat并在防火墙中开放了访问端口,windows中用浏览器可以正常访问看到黄猫的界面,centos7内部自带的火狐浏览器不能访问,显示链接被重置。求助,可能的原因是什么啊? 2、同时我在centos7中部署了nginx反向代理tomcat集群,部署了两台tomcat,并且能够分别正常访问。我在nginx.conf中添加了代理配置,但是通过nginx服务器访问我的项目显示404,查看日志显示请求的路径是nginx安装目录下的html/test,test是我的项目,这是不是说明我的nginx服务器根本没有去tomcat中请求服务,我的请求到nginx中就终止了,他直接到自己的html目录下面查找我的项目,因为没有我的项目,所以报错,为什么会这样啊?(能确保nginx服务器安装无误,gcc等依赖编译包都正确安装,nginx.conf中的配置也确保正确,求助,还会有什么原因导致这种情况) (以上两个问题都是在公司内网环境下,通过代理上网的) 这两个问题困扰我好几天了,希望能够得到广大猿友们帮助QAQ nginx.conf配置文件: #user nobody; worker_processes 1; events { worker_connections 1024; } 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 logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; upstream tomcat_server{ server 127.0.0.1:8090; server 127.0.0.1:8000; server 127.0.0.1:8081; server 127.0.0.1:8082; ip_hash; } server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; proxy_pass http://tomcat_server; } #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 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} } nginx日志: 1 2018/02/08 12:10:40 [error] 12057#0: *11 open() "/usr/local/nginx/html/test" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /test HTTP/1.1", host: "192.168.200.131" 2 2018/02/08 12:31:47 [error] 12057#0: *15 open() "/usr/local/nginx/html/test" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /test HTTP/1.1", host: "192.168.200.131" 3 2018/02/08 12:31:47 [error] 12057#0: *15 open() "/usr/local/nginx/html/favicon.ico" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /favicon.ico HTTP/1.1", host: "192.168.200.131" 4 2018/02/08 12:40:13 [error] 12057#0: *17 open() "/usr/local/nginx/html/test" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /test HTTP/1.1", host: "192.168.200.131" 5 2018/02/11 10:05:04 [notice] 2863#0: signal process started 6 2018/02/11 10:05:16 [error] 2864#0: *1 open() "/usr/local/nginx/html/favicon.ico" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /favicon.ico HTTP/1.1", host: "192.168.200.131", referrer: "http://192.168.200.131/" 7 2018/02/11 10:05:21 [error] 2864#0: *3 open() "/usr/local/nginx/html/test" failed (2: No such file or directory), client: 192.168.200.11, server: localhost, request: "GET /test HTTP/1.1", host: "192.168.200.131"
tomcat集群使用nginx加redis实现session共享出现BUG
>> 启动 Tomcat 成功,操作报错信息如下: - Caused by: java.lang.ClassNotFoundException: com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve 触发原因:context.xml 配置信息和引入的jar版本不一致 解决方案:按照文档重新配置 使用jdk1.8,nginx1.11.4,redis-2.8.9,tomcat7.0.61 使用了commons-logging-1.2.jar,commons-pool2-2.4.2.jar,jedis-2.8.2.jar,tomcat-juli.jar,tomcat-redis-session-manage-tomcat7.jar 请问是什么原因,能给一个正确的jar和配置吗
用apache或nginx做集群负荷分担,能不能动态的增加或减少tomcat处理节点?
用apache或nginx做集群负荷分担,能不能动态的增加或减少tomcat处理节点? 问题是这样的 我的一个应用,目前是用apache用负载均衡,用mod_jk连接了3个tomcat。但是tomcat中的WEBAPP不知道哪里有问题,经常出现线程挂死,空占CPU的情况,这时只能把这个tomcat重启。 在重启的的瞬间,apache还是会向这个tomcat分发请求,而tomcat重启之后也需要30秒时间来装载应用里的缓存数据,这个时候如果apache把请求分过来,tomcat不会有正确的结果返回。 请问有没有让apache或nginx在运行时手动增加或停止后端节点的方法?让tomcat完全重启后再分发请求过来呢?
Linux下apache+tomcat集群失败
我的系统版本是Centos5.4,分别根据如下两篇文章进行配置调试: 1. http://blog.csdn.net/bluishglc/article/details/6867358 2. http://wapwenku.baidu.com/view/8cfa95b265ce05087632138d?pn=4&vw=all&ssid=&from=&bd_page_type=1&uid=814367CBCBCC9B08051E537890C27D44&pu=rc@1,pic@on,sl@1,pw@500,sz@176_208,pd@1,fz@2,lp@25,tpl@wml,&st=1&wk=rd&maxpage=7&pos=all apache是装在linux环境的,tomcat是装在我本机windows7的,集群之后访问测试地址并没有跳转到tomcat的地址,而是报404 file not found,请问有做过的朋友遇到过类似问题么,配了好几天都快无力了。感觉是链接apache和tomcat的中间模块没有成功执行的问题。apache也没有log日志,访问localhost正常。 ps:在windows上apache+tomcat成功,linux下nginx+tomcat也成功,唯独apache+tomcat在linux上有问题。
nginx 和 weblogic集群 矛盾?
最近做了nginx 反向代理 负载均衡 demo ,是用tomcat 做server 配了三台实验通过.但是公司服务器是weblogic,我觉得nginx 这个代理功能和weblogic 集群功能差不多,ps我没搭过weblogic集群,只是了解. 如果只是负载均衡 有必要用nginx做前端吗?网上看有些人说 nginx + weblogic集群 我更蒙b了,一起用 ?有什么用?
tomcat集群使用nginx作反向代理,共享session后出错,无法跳转页面
![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368719_200875.png) ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368731_696030.png) ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368741_682484.png) ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368751_350991.png) ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368768_49180.png) ![图片说明](https://img-ask.csdn.net/upload/201712/04/1512368777_716919.png) 共享session后,两个tomcat已经能共享session了,但通过nginx做负载均衡后,页面能登录成功,但退出删除session时,跳转到了tomcat/loadBalance1/Logout,这是什么问题呢,跪求大神解决,如果需要别的部分代码,也可以发出来,坐等大神,跪谢
为什么我的nginx+tomcat的访问速度很慢?
配置文件,我只在默认的配置上面,新增了upstream 访问nginx,然后nginx分发请求,速度非常慢 现在还不清楚为什么这么慢,难道还需要配置其他东西? ``` #user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } 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 logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; #tomcat服务器地址 upstream toms { server localhost:8080; server localhost:8081; } server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { proxy_pass http://toms; } #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 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m; # ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} } ```
关于Nginx 集群问题,真实服务器是tomcat还是nginx
upstream localhost { server 192.168.1.101:8080; server 192.168.1.102:8090; } 我想问一下,这个1.101和1.102还是用nginx吗?还是用什么服务器, 如果是用nginx,1.101如何部署
关于linux服务器tomcat与nginx集群出现java web内置对象丢失,界面数据同步等问题
线上部署了一个javaweb项目,出现通过单独tomcat8080访问程序一切正常,通过nginx转发进入, 就会出现页面内容总是第一次访问的内容,管理界面出现数据与数据库不同步的现象,困扰了很久了, 求师兄师姐们给支个招。。。。拜托
一般的集群可以达到多少并发?
Nginx+tomcat配置集群负载均衡 我在网上看到,一般都是这个组合的教程 这个东西可以达到多少并发? 像春晚的时候,几亿人同时在线,那是怎么做到的...
Linux下用redis+tomcat实现session共享
redis可以是集群~ Nginx+tomcat+redis也可以
centos7 下apache+tomcat+jk负载均衡
在linux下安装apache成功。,安装了两个tomcat,测试项目测试负载均衡成功,但是测试session复制不成功。相同的配置信息,在windows下,负载跟session的复制都是成功的,后来我就使用nginx负载集群。在windows下同样都成功。。。但是就是在linux 下的时候只有负载成功了,但是session复制没有成功。。。。。。急求解决方案啊?、linux新手。。。求教
阿里云服务器不能用keepalived.....?
阿里云服务器不能用keepalived+nginx+tomcat搭建高可用集群吗??? 有什么解决办法吗?? 求指点
redis 3.0后的集群如何搭建session共享(tomcat)
redis单点配合tomcat+nginx搭建的高并发环境, sessionmanager是可以找到的, 那么如果 redis变成了集群(redis cluster), 那么sessionmanager以及他的配置过程是否会有所不同 但是我知道redis cluster是可以通过任意集群中的节点重定向请求到对应的节点的, 那么 为什么还需要额外的配置或额外的代码呢?
一个请求是怎么样从DNS到nginx ,然后从nginx访问到dubbo服务的?麻烦说说访问流程
架构: DNS nginx+keepalived(反向代理、web层负载均衡); dubbo+zookeeper(服务端,服务注册和负载均衡); 缓层:redis3.0集群 数据库分库分表中间件:sharding-JDBC 数据库:mysql
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
相关热词 c#如何定义数组列表 c#倒序读取txt文件 java代码生成c# c# tcp发送数据 c#解决时间格式带星期 c#类似hashmap c#设置istbox的值 c#获取多线程返回值 c# 包含数字 枚举 c# timespan
立即提问