centos 测试io centos7
很多朋友对于centos 测试io和centos7不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
【fio】CentOS.x上磁盘性能测试工具fio的安装和使用
Summary: Multithreaded IO generation tool
Description: fio is an I/O tool that will spawn a number of threads or processes doing a particular type of io action as specified by the user. fio takes a number of global parameters, each inherited by the thread unless otherwise parameters given to them overriding that setting is given.
The typical use of fio is to write a job file matching the io load one wants to simulate.
多线程IO生成工具
fio是一个I/ O工具,它将产生许多线程或正在执行的进程,由用户指定的特定类型的io操作。
fio需要一个全局参数的数量,每个参数都由线程继承,否则给他们的参数将覆盖该设置。
fio的典型用法是编写与io负载匹配的需要模拟的作业文件。
官网地址:
# yum-y install libaio gtk2 libaio-devel gtk2-devel
# yum-y install fio
# yum info fio
# rpm-ql fio| grep"bin"
应用使用IO通常有二种方式:同步和异步。
同步的IO一次只能发出一个IO请求,等待内核完成才返回,这样对于单个线程iodepth总是小于1,但是可以透过多个线程并发执行来解决,通常我们会用16-32根线程同时工作把iodepth塞满。
异步的话就是用类似libaio这样的Linux native aio一次提交一批,然后等待一批的完成,减少交互的次数,会更有效率。
注意:性能测试建议直接通过写裸盘的方式进行测试,会得到较为真实的数据,但直接测试裸盘会破坏文件系统结构,导致数据丢失,请在测试前确认磁盘中数据已备份。
# fio -direct=1 -iodepth=64 -rw=read -ioengine=libaio -bs=4k -size=10G -numjobs=1 -name=./fio.test
"-direct=1",代表采用非 buffered I/O文件读写的方式,避免文件读写过程中内存缓冲对性能的影响
"-iodepth=64"和"-ioengine=libaio"这两个参数,这里指文件读写采用异步 I/O(Async I/O)的方式,也就是进程可以发起多个 I/O请求,并且不用阻塞地等待 I/O的完成。稍后等 I/O完成之后,进程会收到通知。这种异步 I/O很重要,因为它可以极大地提高文件读写的性能。在这里我们设置了同时发出 64个 I/O请求
"-rw=read,-bs=4k,-size=10G",这几个参数指这个测试是个读文件测试,每次读 4KB大小数块,总共读 10GB的数据。最后一个参数是"-numjobs=1",指只有一个进程/线程在运行。所以,这条 fio命令表示我们通过异步方式读取了 10GB的磁盘文件,用来计算文件的读取性能。
我们看到在上图中测试中, I/O性能是 15.9MB/s的带宽,IOPS(I/O per second)是 4076左右。
fio压测工具和io队列深度理解和误区
fio– IO压力测试工具
fio安装使用方法
fio模拟MySQL服务器IO压力脚本
fio使用详解
Fio Output Explained
centos怎样编写tomcat宕机自动重新启动
一、设置tomcat定时启动
1,首先将tomcat注册为服务,先打开tomcat的bin目录下service.bat文件,修改下面的值,这是sevvice的注册名称和显示名称,一般可使用默认值。
set SERVICE_NAME=Tomcat7
set PR_DISPLAYNAME=Apache Tomcat
【然后修改jvm大小,搜索到--JvmMs 128--JvmMx 256进行修改,因为做成服务启动,启动的时候就不会用到 catalina.bat,也就不会读取里面的jvm设置了。】(可选,可以不设置)
然后运行cmd命令窗口,cd到tomcat的bin目录下,运行下面的命令
service.bat install运行成功过后,会提示服务已经安装成功。
2,制作重启脚本restart.bat,文件内容如下
net stop Tomcat7 net start Tomcat7
3,利用控制面板里面的“任务计划”设置第2步的脚本运行时间计划
4,如果想删除服务,也很简单,先把服务停掉,然后在cmd窗口运行下面的命令即可,后面那个Tomcat7是服务名。
sc delete Tomcat7
需要注意的是,需要先把服务停掉,才能一次删除成功,或者删除之后再停止服务,就会发现服务已经删除成功了。
二、监听tomcat
只要运行start.bat即可,相关配置在config.properties文件中,默认即可,如果服务名不对应就修改关闭和启动命令的服务名即可:net start【Tomcat7】括号中服务名,然后运行start.bat
下面是具体的监听代码:
首先是监听类TomcatMonitor.java:
[java] view plain copy
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.util.Properties;
/**
*@describe:TomcatMonitor.java
*
*@date 2016-7-4
*@author liuweilong
*/
public class TomcatMonitor implements Runnable{
String start="";//系统命令启动
String stop="";//系统命令关闭
String testHttp="";//测试连接地址
int testIntervalTime=1;//测试连接间隔时间,单位为秒
int waitIntervalTime=2;//等待测试间隔时间,单位为秒
int testTotalCount=5;//测试连接总次数
Thread thread=null;
public TomcatMonitor(){
InputStream in= TomcatMonitor.class.getResourceAsStream("config.properties");
Properties p= new Properties();
try{
p.load(in);
stop=p.getProperty("stop");
start=p.getProperty("start");
testHttp=p.getProperty("testHttp");
testIntervalTime=Integer.parseInt(p.getProperty("testIntervalTime"));
waitIntervalTime=Integer.parseInt(p.getProperty("waitIntervalTime"));
testTotalCount=Integer.parseInt(p.getProperty("testTotalCount"));
} catch(Exception e){
e.printStackTrace();
}
System.out.println("*******************初始化成功!*******************");
thread=new Thread(this);
thread.start();
}
public void run(){
System.out.println("正在监控中...");
int testCount=0;
while(true){
testCount=0;
testCount++;
boolean isrun=test();
System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));
while(!isrun){
if(testCount>=testTotalCount)break;
try{
thread.sleep(testIntervalTime*1000);
} catch(InterruptedException e){
e.printStackTrace();
}
testCount++;
System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));
isrun=test();
}
if(!isrun){
try{
//关闭tomcat服务
Process proc= Runtime.getRuntime().exec(stop);
thread.sleep(5000);
//启动tomcat服务
System.out.println("测试连接失败,正在重启tomcat");
Process p=Runtime.getRuntime().exec(start);
System.out.println("重启tomcat成功");
}catch(Exception e){
e.printStackTrace();
System.out.println("重启tomcat异常,请查看先关错误信息。。。。。");
}
}
try{
thread.sleep(waitIntervalTime*1000);
} catch(InterruptedException e){
e.printStackTrace();
}
isrun=test();
}
}
public boolean test(){
URL url=null;
try{
url= new URL(testHttp);
} catch(MalformedURLException e){
e.printStackTrace();
}
try{
URLConnection urlConn=url.openConnection();
urlConn.setReadTimeout(15000);
BufferedReader reader= new BufferedReader(new InputStreamReader( urlConn.getInputStream()));//实例化输入流,并获取网页代码
String s;
while((s= reader.readLine())!= null){
return true;
}
} catch(Exception e){
return false;
}
return false;
}
public static void main(String[] args) throws Exception{
TomcatMonitor tm=new TomcatMonitor();
}
}
然后是对应的配置文件config.properties:
[plain] view plain copy
#系统命令启动
start=net start Tomcat7
#关闭
stop= net stop Tomcat7
#测试连接总次数
testTotalCount=3
#连接失败时,再次检测时间间隔,单位为秒
testIntervalTime=3
#连接超时时间,即多少秒tomcat没响应视为宕机,单位为秒
connectionTimeout=15
#tomcat启动时间,防止在tomcat尚未启动完成的时候,程序又去检验tomcat状态,造成尚未启动完成又重新启动,单位为秒
tomcatStartTime=600
#测试连接地址
testHttp=
#正常情况下,每次检测间隔时间,单位为秒
waitIntervalTime=30
最后是启动的start.bat:
[plain] view plain copy
java-cp. TomcatMonitor
超详细Centos 6.5 文本模式图文系统安装教程
对于刚接触Linux的用户来说,安装系统和配置网卡的过程也可能要用很长的时间,Centos6.5的安装方式有二种,图形模式和文本模式。文本模式从6开始就不支持自定义分区了(新手练习时默认分区足够用),如果需要自定义分区要使用图形模式安装。大家在学习Linux时,不需要一开始就在物理机上安装,下面就使用VMware Workstation虚拟机软件演示一下文本模式安装。
演示环境所需要的软件:
虚拟机版本:VMware Workstation12
Linux版本:CentOS-6.5-x86_64-bin-DVD1.iso
下面的过程分为三部分
配置虚拟机
文本模式下安装Centos6.5
配置网卡后使用远程管理工具连接
一、配置虚拟机
打开VM虚拟机软件,单击“文件”-“新建虚拟机”
选择“自定义(高级)”选项,单击“下一步”
硬件兼容性界面选项保持默认单击“下一步”
安装客户机操作系统界面,此处选择“稍后安装系统”以后安装系统也可一直使用此项,设置完成后再添加ISO,这样安装肯定没有问题。(有的版本选第二项添加ISO项后会安装不成功,以及后面要求填写用户名密码等信息),单击“下一步”
这里选择Linux版本选择“CentOS 64位”,单击“下一步”
设置虚拟机名称及存放位置,自己可根据需要随意填写和设置,单击“下一步”
CPU和内存保持默认即可,内存默认是1024MB,二个选项以后可根据自己需要修改,单击“下一步”
网络类型,选项桥接模式,该模式安装完成后配置和本机相同的网段,然后使用远程工具来管理系统。单击“下一步”
IO控制器和虚拟磁盘类型保持默认,单击“下一步”
选择磁盘界面,由于是新安装系统没有硬盘,这里选择“创建新虚拟磁盘”,单击“下一步”
*指定磁盘容量界面:设置磁盘大小,此处默认是20G,可以不做更改(学习用足够),由于我们使用的是虚拟系统,安装完成后,只是创建一个文件与我们的硬盘大小无关。
*此界面不要选择“立即分配所有磁盘空间”如果选中该选项,系统把20G空间一下都分配给该虚拟机,这样很浪费磁盘的空间。
*选择“将虚拟磁盘存储为单个文件”这样在虚拟机文件夹只产生一个文件。
指定磁盘文件界面:是指虚拟机文件放的位置。保持默认,单击“下一步”
单击“自定义硬件”
使用下面的“移除”按钮,删除声卡和打印机,选中CD/DVD,右侧点击浏览选中Centos6.5的ISO文件,设置完成后,单击“关闭”,再单击“完成”。
二、安装系统,文本模式下安装Centos6.5
单击“开启此虚拟机”
开机后,会出现下面的界面,此时不要按“回车”键
界面说明:
Install or upgrade an existing system安装或升级现有的系统
install system with basic video driver安装过程中采用基本的显卡驱动
Rescue installed system进入系统修复模式
Boot from local drive退出安装从硬盘启动
Memory test内存检测
出现上图的界面后,按ESC键,输入linux text,来进入文本安装模式。
是否对CD媒体进行测试,这里选择“Skip”跳过测试。
这是欢迎界面,点击“OK”回车确认
选择安装语言,此处保持默认English。不管是学习和以后使用都建议不要选择中文,“OK”回车确认
键盘选择,默认选择美式键盘即可
这里是安装警告,提示安装系统需要初始化虚拟磁盘,会造成所有数据的丢失
有4个选项:忽略/忽略所有/初始化/初始化所有。
由于我们是新安装,磁盘里没有数据,选择Re-initialize all初始化所有。
选择时区,这里选择亚州上海,注意:没有北京等地区
给系统的root设置密码,最好满足复杂度,否则会提示错误,如设置成Abc@123
下面是磁盘分区,有三个选项
*Use entire drive(使用整个磁盘)
这个方案会删除硬盘上所有分割区,然后再重新分割硬盘。如果您硬盘上有您想保留的操作系统,请不要选择此项。
* Replace exiting Linux system(替换掉现有的 Linux系统)
这个方案会删除硬盘上所有 GNU/Linux分割区,然后再重新分割硬盘。这种方案不会删除其他操作系统的分割区。如果您硬盘上有您想保留的 GNU/Linux系统,请不要选择此项。
*Use free space(使用可用空间)
这个方案不会删除任何分割区,只使用尚未分给任何分割区的空间进行自动分割。如果您的硬盘早已被另一个操作系统占用了,此项用不了。
由于我们是新建的硬盘,所以直接使用Use entire drive安装即可。
提示开始写数据,选择Write changes to disk
安装完成,提示reboot重启,该过程根据机器性能,3-5分钟可安装完成
进入系统界面,输入
localhost login:root
Password:密码输入时不会显示,输入完成后按回车即可
三、配置网卡后使用远程管理工具连接
输入:vi etc/sysconfig/network-scripts/ifcfg-eth0
按回车,出现如下界面,按i进入编辑模式,按第二张图所示的模式,填写自己的静态IP地址、网关等信息,填写完成后按esc键退出编辑模式,输入:wq(保存退出)
DEVICE=eth0
HWADDR=00:0C:29:E5:2E:02
TYPE=Ethernet
UUID=8e6b6bfc-da88-4715-8d5e-c666ce949d42
ONBOOT=yes开启自动启用网络连接
NM_CONTROLLED=yes
BOOTPROTO=static启用静态IP地址
IPADDR=10.3.20.66设置IP地址
NETMASK=255.255.255.0设置子网掩码
GATEWAY=10.3.20.1设置网关
DNS1=8.8.8.8设置主DNS
DNS2=114.114.114.114设置备DNS
重启网卡输入[root@localhost~]#/etc/init.d/network restart,回车后,提示网卡重启
最后使用远程连接工具SecureCRT(Xshell等工具)连接,如下图所示
这样基本上就ok了