本文目录一览:
- 1、end time 与Maximum Number Of Cycles如何协调设置
- 2、送分~!DREAMWEAVER的问题
- 3、艾尔登法环xss帧数
- 4、《艾尔登法环》支持光追不画质怎么样啊?
- 5、推荐5000元左右组装台式机配置,玩游戏为主
- 6、什么是 CSRF攻击?
end time 与Maximum Number Of Cycles如何协调设置
1. Resin安装及自启动设置
创建开机自动启动
cp contrib/init.resin /etc/rc.d/init.d/resin
vi /etc/rc.d/init.d/resin
设置正确的路径
JAVA_HOME=/usr/local/jdk1.6.0_13
RESIN_HOME=/usr/local/resin-3.1.8
赋予可执行权限
chmod +x /etc/rc.d/init.d/resin
加为自启动服务:
chkconfig --add resin
chkconfig --level 35 resin on
service resin start
解决启动服务错误: log_daemon_msg: command not found
将该函数调用到的地方注释掉并用echo 来代替。如:
log_daemon_msg “resin start”
改为
echo “resin start”
修改好后可以用service resin start/stop/restart来执行相关的命令。
2. 设置resin.conf参数及JVM设置
jvm-arg-Xmx4096m/jvm-arg
jvm-arg-Xms4096m/jvm-arg
jvm-arg-Xmn512M/jvm-arg
jvm-arg-Xss50M/jvm-arg
jvm-arg-XX:PermSize=768M/jvm-arg
jvm-arg-XX:MaxPermSize=768M/jvm-arg
jvm-arg-XX:SurvivorRatio=8/jvm-arg
jvm-arg-XX:MaxTenuringThreshold=7/jvm-arg
jvm-arg-XX:GCTimeRatio=19/jvm-arg
jvm-arg-XX:+UseParNewGC/jvm-arg
jvm-arg-XX:+UseConcMarkSweepGC/jvm-arg
jvm-arg-XX:+CMSPermGenSweepingEnabled/jvm-arg
jvm-arg-XX:+CMSClassUnloadingEnabled/jvm-arg
jvm-arg-XX:+UseCMSCompactAtFullCollection/jvm-arg
jvm-arg-XX:CMSFullGCsBeforeCompaction=2/jvm-arg
jvm-arg-XX:-CMSParallelRemarkEnabled/jvm-arg
jvm-arg-XX:+DisableExplicitGC/jvm-arg
jvm-arg-XX:CMSInitiatingOccupancyFraction=70/jvm-arg
jvm-arg-XX:SoftRefLRUPolicyMSPerMB=0/jvm-arg
jvm-arg-XX:+PrintClassHistogram/jvm-arg
jvm-arg-XX:+PrintGCDetails/jvm-arg
jvm-arg-XX:+PrintGCTimeStamps/jvm-arg jvm-arg-XX:+PrintGCApplicationConcurrentTime/jvm-arg
jvm-arg-XX:+PrintGCApplicationStoppedTime/jvm-arg
jvm-arg-Xloggc:log/gc.log/jvm-arg
jvm-arg-Xdebug/jvm-arg
jvm-arg-Dcom.sun.management.jmxremote/jvm-arg
内存设置配置:
memory-free-min5M/memory-free-min
最大线程数
!-- Maximum number of threads. --
thread-max1024/thread-max
!-- Configures the socket timeout --
socket-timeout65s/socket-timeout
配置最活连接和超时时间
!-- Configures the keepalive --
keepalive-max2048/keepalive-max
keepalive-timeout15s/keepalive-timeout
3. 配置jconsole监控JVM
$JAVA_HOME/jre/lib/management/jmxremote.password.template的文件是远程连接时的设置用户和密码的文件,
cp $JAVA_HOME/jre/lib/management/jmxremote.password.template $JAVA_HOME/jconsole/jmxremote.password
chmod 600 $JAVA_HOME/jconsole/jmxremote.password
vi jmxremote.password
去掉#monitorRole RED前的注释并将RED修改为你要设置的密码。在resin.conf加入以下配置,其中被监控主机的IP需要和主机IP一致
jvm-arg-Dcom.sun.management.jmxremote.port=12345/jvm-arg
jvm-arg-Dcom.sun.management.jmxremote.ssl=false/jvm-arg
jvm-arg-Dcom.sun.management.jmxremote.access.file=/usr/local/jdk1.6.0_13/jre/lib/management/jmxremote.access/jvm-arg jvm-arg-Dcom.sun.management.jmxremote.password.file=/usr/local/jdk1.6.0_13/jre/lib/management/jmxremote.password/jvm-arg
jvm-arg-Dcom.sun.management.jmxremote.authenticate=true/jvm-arg
jvm-arg-Djava.rmi.server.hostname=192.168.100.9/jvm-arg
在客户端基本不用怎么设置,在 JDK 安装目录中(JDK_HOME/bin/jconsole.exe)启动 jconsole.exe 就可以打开主界面。输入192.168.100.9:12345 用户名和密码即可看到监控界面中关于jvm的相关信息。操作
双击jconsole.exe启动连接对话框
4. 配置Resin后台管理
management path="${resin.root}/admin"
user name="admin" password="MnHpobDOvrMOyQFWoa5w7A=="/
resin:if test="${resin.professional}"
deploy-service/
jmx-service/
log-service/
xa-log-service/
/resin:if
/management
web-app id="/resin-admin" root-directory="${resin.home}/php/admin"
!--
- Administration application /resin-admin--
prologue
resin:set var="resin_admin_user" value="admin"/
resin:set var="resin_admin_password" value="password"/
resin:set var="resin_admin_external" value="true"/
resin:set var="resin_admin_insecure" value="true"/
/prologue
/web-app
二. 网络优化部分
1. 减少TCP连接中的TIME-WAIT或 CLOSE-WAIT包
Vim /etc/sysctl.conf加入以下配置
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_fin_timeout = 15
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.tcp_keepalive_probes = 5
net.ipv4.tcp_keepalive_intvl = 15
配置属性说明:
net.ipv4.tcp_syncookies = 1 表示开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;
net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。
tcp_syn_retries :INTEGER
默认值是5
对于一个新建连接,内核要发送多少个 SYN 连接请求才决定放弃。不应该大于255,默认值是5,对应于180秒左右时间。(对于大负载而物理通信良好的网络而言,这个值偏高,可修改为2.这个值仅仅是针对对外的连接,对进来的连接,是由tcp_retries1 决定的)
tcp_synack_retries :INTEGER
默认值是5
对于远端的连接请求SYN,内核会发送SYN + ACK数据报,以确认收到上一个 SYN连接请求包。这是所谓的三次握手( threeway handshake)机制的第二个步骤。这里决定内核在放弃连接之前所送出的 SYN+ACK 数目。不应该大于255,默认值是5,对应于180秒左右时间。(可以根据上面的 tcp_syn_retries 来决定这个值)
tcp_keepalive_time :INTEGER
默认值是7200(2小时)
当keepalive打开的情况下,TCP发送keepalive消息的频率。(由于目前网络攻击等因素,造成了利用这个进行的攻击很频繁,曾经也有cu的朋友提到过,说如果2边建立了连接,然后不发送任何数据或者rst/fin消息,那么持续的时间是不是就是2小时,空连接攻击? tcp_keepalive_time就是预防此情形的.我个人在做nat服务的时候的修改值为1800秒)
tcp_keepalive_probes:INTEGER
默认值是9
TCP发送keepalive探测以确定该连接已经断开的次数。(注意:保持连接仅在SO_KEEPALIVE套接字选项被打开是才发送.次数默认不需要修改,当然根据情形也可以适当地缩短此值.设置为5比较合适)
tcp_keepalive_intvl:INTEGER
默认值为75
探测消息发送的频率,乘以tcp_keepalive_probes就得到对于从开始探测以来没有响应的连接杀除的时间。默认值为75秒,也就是没有活动的连接将在大约11分钟以后将被丢弃。(对于普通应用来说,这个值有一些偏大,可以根据需要改小.特别是web类服务器需要改小该值,15是个比较合适的值)
再执行以下命令,让修改结果立即生效:/sbin/sysctl -p
用以下语句看了一下服务器的TCP状态:
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
三. 解决Too many open files问题
Too many open files 问题出现有两种情况:
一种是在搜索的时候出现,多半是由于索引创建完毕之后被移动过,如果创建索引的时候不出现该错误,搜索的时候也一般是不会出现的。如果出现了,有两种处理办法,一种是修改合并因子和最小合并因子,并且使用
IndexWriter.Optimize() 优化索引,这样会将索引文件数量减少到文件系统限制之内;另外一种办法是修改操作系统的打开文件数量限制。方法如下:
按照最大打开文件数量的需求设置系统, 并且通过检查/proc/sys/fs/file-max文件来确认最大打开文件数已经被正确设置。 配置操作如下:
# cat /proc/sys/fs/file-max
如果设置值太小, 修改文件/etc/sysctl.conf的变量到合适的值。 这样会在每次重启之后生效。
# echo 65535 /proc/sys/fs/file-max
编辑文件/etc/sysctl.conf,插入下行。
fs.file-max = 65535
执行sysctl –p生效
设置ulimit –n 65535
在/etc/security/limits.conf文件中设置最大打开文件数, 下面是一行提示:
#
添加如下这行。
* - nofile 65535
这行设置了每个用户的默认打开文件数为2048。 注意"nofile"项有两个可能的限制措施。就是项下的hard和soft。 要使修改过得最大打开文件数生效,必须对这两种限制进行设定。 如果使用"-"字符设定, 则hard和soft设定会同时被设定。
硬限制表明soft限制中所能设定的最大值。 soft限制指的是当前系统生效的设置值。 hard限制值可以被普通用户降低。但是不能增加。 soft限制不能设置的比hard限制更高。 只有root用户才能够增加hard限制值。
当增加文件限制描述,可以简单的把当前值双倍。 例子如下, 如果你要提高默认值1024, 最好提高到2048, 如果还要继续增加, 就需要设置成4096。
另外一种情况是在创建索引的时候,也有两种可能,一种是合并因子太小,导致创建文件数量超过操作系统限制,这时可以修改合并因子,也可以修改操作系统的打开文件数限制;另外一种是合并因子受虚拟机内存的限制,无法调整到更大,而 需要索引的doc 数量又非常的大,这个时候就只能通过修改操作系统的打开文件数限制来解决了。
在系统访问高峰时间以root用户执行以下的脚本,可能出现的结果如下:
# lsof -n|awk '{print $2}'|sort|uniq -c |sort -nr|more
131 24204
57 24244
其中第一行是打开的文件句柄数量,第二行是进程号。得到进程号后,我们可以通过ps命令得到进程的详细内容。
ps -aef|grep 24204
mysql 24204 24162 99 16:15 ? 00:24:25 /usr/sbin/mysqld
系统默认程打开最多文件句柄数值1024。但是如果系统并发特别大,尤其是squid服务器,很有可能会超过1024。这时候就必须要调整系统参数,以适应应用变化。Linux有硬性限制和软性限制。可以通过ulimit来设定这两个参数。方法如下,以root用户运行以下命令:
ulimit -HSn 4096 以上命令中,H指定了硬性大小,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。设定句柄数量后,系统重启后,又会恢复默认值。如果想永久保存下来, /etc/security/limits.conf
送分~!DREAMWEAVER的问题
select是数据查询语言,其语法如下:
SELECT 列名的列表
[INTO 新表名]
[FROM 表名与视图名列表]
[WHERE 条件表达式]
[GROUP BY 列名的列表]
[HAVING 条件表达式]
[ORDER BY 列名1[ASC|DESC],列名2[ASC|DESC], ... 列名n[ASC|DESC]]
简单地可以说明为,按照指定的条件由指定的表中查询出指定的列。
如果你想知道参数的用法,我再给你传。
上面语句只能查看一个表,当我们要查看多个表时就要把多个表联在一起变成一个表,inner join 是内联接的关键词,是按照一定条件把两个表联在一起,联接后的表包含两个表的所有列(两个表进行笛卡尔积),但只保留两个表中符合条件的行,用法如下:
SELECT 列名的列表
FROM 表1 inner join 表2 on
表1.列名=表2.列名
例:
有三个表:
销售商表(XSS)
XSBH XSNC DQ FZR DH BZ
000001 广电公司 南京 张三 11111111 NULL
000002 家电市场 无锡 李四 22222222 NULL
000003 电器商场 上海 王五 33333333 NULL
000004 小家电商场 南京 赵六 44444444 NULL
产品表(CP)
CPBH CPMC JG KCL
100001 彩色电视机 3000 10
100002 洗衣机 1200 20
100003 冰箱 1800 12
100004 电热水器 2000 30
100005 太阳能热水器 2200 8
100006 1匹空调 1800 5
100007 1.5匹空调 2400 20
100008 2匹空调 3800 6
100009 音响 3500 3
100010 台式电脑 6000 5
100011 MP3 900 10
100012 复读机 200 20
销售产品表(XSCP)
CPBH XSBH XSRQ SL JE
100001 000001 2004-3-10 1 3000
100001 000003 2004-5-20 2 6000
100002 000001 2004-3-12 1 1200
100002 000002 2004-2-22 2 2400
100002 000003 2004-5-29 3 3600
100010 000004 2004-6-15 4 4500
100001 000001 2004-3-10 1 3000
100001 000003 2004-5-20 2 6000
100002 000001 2004-3-12 1 1200
100002 000002 2004-2-22 2 2400
100002 000003 2004-5-29 3 3600
100010 000004 2004-6-15 4 4500
(1)查询每种产品的所有数据。(产品表的所有列)
Select * from CP
(2)查询每种产品的价格和库存量。(产品表的JG ,KCL两列)
Select JG ,KCL from CP
(3)查询XSBH 为000001的销售商的地区和电话。
Select DQ,DH from XSS where XSBH=‘000001’
上面是对一个表操作,当我们要同时查看两个表的内容如:
(4)查询已销售产品的价格、库存量、销售日期和销售数量。
SELECT CP.JG,CP.KCL,XSCP.XSRQ,XSCP.SL FROM CP inner join XSCP on CP.CPBH=XSCP.CPBH
注:(1)已销售产品指XSCP表中记录的产品
(2)CP.JG表示:CP表的JG列,如果JG列只存在于一个表中,可省略CP.
所以还可以写成:
ELECT JG,KCL,XSRQ,SL FROM CP inner join XSCP on CP.CPBH=XSCP.CPBH
艾尔登法环xss帧数
艾尔登法环xss帧数最高是60。
Xbox Series S:简称xss,分辨率最高 2560x1440、最高 60 帧、支持 HDR、不支持光线追踪。
拓展:
PC:分辨率最高 3840x2160、最高 60 帧、支持 HDR、支持光线追踪;
PS4:分辨率最高 1920x1080、最高30 帧、支持 HDR、不支持光线追踪;
PS4 Pro:分辨率最高 3200x1800、最高 30 帧、支持 HDR、不支持光线追踪;
PS5:分辨率最高 3840x2160、最高 60 帧、支持 HDR、支持光线追踪;
Xbox One(含 S):分辨率最高 1600x900、最高 30 帧、不支持 HDR、不支持光线追踪;
Xbox One X:分辨率最高 3840x2160、最高 30 帧、支持 HDR、不支持光线追踪;
Xbox Series X:分辨率最高3840x2160、最高 60 帧、支持 HDR、支持光线追踪。
《艾尔登法环》支持光追不画质怎么样啊?
PC端
最高可实现4K(3840×2160P)画质、60FPS并支持HDR及光追效果。
PS平台
PS4:最高1920×1080P、30帧,支持HDR;
PS4 Pro:最高3200×1800P(棋盘格)、30帧,支持HDR;
PS5:最高4K、最高60帧(性能模式下),支持HDR及光追(更新补丁后);
Xbox平台
Xbox One S:最高1600×900P、30帧;
Xbox One X:最高4K、30帧,支持HDR;
XSS:最高2K、最高60帧(性能模式下),支持HDR;
XSX:最高4K、最高60帧(性能模式下),支持HDR及光追(更新补丁后)
推荐5000元左右组装台式机配置,玩游戏为主
可以参考这款配置:
CPU
英特尔32纳米
酷睿i3
双核处理器
i3
2120盒装CPU(LGA1155/3.3GHz/3M三级缓存)
¥740
主板
映泰(BIOSTAR)B75MU3+主板(Intel
B75/LGA
1155)。479元。
内存
金士顿DDR3
1333
4G
台式机内存
¥139
显卡迪兰恒进(Dataland)HD6850恒金1G
775/4000
1024M/256位
GDDR5.
899元
硬盘
希捷500G
ST500DM002
7200转
16M
SATA
6Gb/秒
建达蓝德
盒装正品
¥420
机箱
航嘉电脑机箱
C611
黑色(不含电源)
¥89
电源
安钛克(Antec)VP
450P
额定450W
120mm静音风扇
主动PFC
电源。289元。
键盘鼠标
惠普WB365PA#AB2
藏羚羊二代键鼠套装(键盘PS/2,鼠标USB)
¥49
音箱
漫步者
R201T12
全新升级版2.1多媒体音箱
音质更出色
黑色
¥189
显示器
AOC(冠捷)2217V+
22英寸宽屏液晶显示器
(黑色)
¥819
合计:4019元。
什么是 CSRF攻击?
,即在某个恶意站点的页面上,促使访问者请求你的网站的某个 URL(通常会用 POST 数据方式),从而达到改变服务器端数据的目的。这一类攻击依赖于你的网页中的表单,脆弱的表单很容易受到攻击。对于你网站中的访问者而言,可能会受到以下攻击: * 在你的网站之外记录受攻击者的日志(比如:Slashdot); * 修改受攻击者在你的网站的设置(比如:Google); * 修改你的硬件防火墙; * 使用受攻击者的登录信息在你的网站中发表评论或留言; * 将资金转移到另一个用户帐号中。 CSRF 攻击的典型是那些使用 cookie 记录登录信息的网站,但对于一些允许某个 IP 地址访问的页面(如内部网),这一类攻击也会奏效。 CSRF 攻击通常会使用到 JavaScript(但不仅限于 JavaScript)实现跨站点自动提交表单--表单数据可以隐藏,提交按钮可以伪装成链接或滚动条。 * 确定那些接受可改变服务器数据的 CGI 只接受 POST 参数,不接受 GET 参数,一些服务器端语言默认同时接受两种方式提交过来的参数; * 确定表单提交处理的是你自己的表单,可以使用一个隐藏字段中存放MD5字符串,此字符串是将登录 cookie 数据与服务器端存放的密钥进行 MD5 之后的结果,只有这个 MD5 字符串正确时才接受表单数据; * 另外还可以增加一个更为严格的方法:在表单中增加一个时间戳的隐藏字段,并将其包含到 hash 字符串中,如果时间戳超过某个时间,则认为表单已过期。当表单过期时,给出一个方法可以让用户重新提交表单,比如将用户之前填写的数据依旧放入表单中,但使用一个新的 hash 字符串。 一个PHP的表单例子,表单代码:?php$key = y8s4Z7m2; //MD5加密密钥$time = time(); //当前时间 $hash = md5($time.$key); //hash 字符串?form method="post" action="comment.php" pYour name: input type="text" name="person_name" //p pComment: /textarea name="comment" rows="10" cols="60"/textarea/p input type="hidden" name="time" value="?php echo $time; ?" / input type="hidden" name="hash" value="?php echo $hash; ?" / pinput type="submit" name="comment" value="Submit Comment" //p/form表单提交之后的 comment.php 后台处理程序代码:?php$key = y8s4Z7m2; //密钥,与上面的一致 $expire = 1800; //表单过期时间:半小时 $my_hash = md5($_POST[time].$key); //正确的 hash 字符串 if ($my_hash != $_POST[hash]) //hash 字符串不正确 die(非法表单提交。); if (time() - $_POST[time] $expire) { //表单已经过期,生成新的时间戳和 hash 字符串,显示表单让用户重新提交。(此处省略)//….}//表单验证通过,可以接受表单提交的数据,并进行其它操作。 //….?