linux top cpu usage

Linux 2016. 2. 15. 18:25

리눅스 top 이 실행된 상태에서 키보드 숫자 1을 누르면 상세한 cpu상태를 알 수 있다.

아래와 같은 그림이 나오는데 Cpu0 ~ Cpu7 까지 있다는 것은 quad core cpu 2개가 장착되어 있기 때문이다.


top - 18:19:45 up 1614 days, 11 min,  3 users,  load average: 3.99, 19.67, 38.17

Tasks: 212 total,   2 running, 210 sleeping,   0 stopped,   0 zombie

Cpu0  : 18.3%us,  1.0%sy,  0.0%ni, 80.0%id,  0.7%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu1  : 11.7%us,  1.3%sy,  0.0%ni, 86.7%id,  0.3%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu2  : 26.6%us,  1.3%sy,  0.0%ni, 52.5%id, 19.6%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu3  : 17.9%us,  4.3%sy,  0.0%ni, 76.4%id,  1.0%wa,  0.0%hi,  0.3%si,  0.0%st

Cpu4  : 10.3%us,  2.0%sy,  0.0%ni, 86.7%id,  0.3%wa,  0.3%hi,  0.3%si,  0.0%st

Cpu5  : 16.3%us,  2.7%sy,  0.0%ni, 79.0%id,  2.0%wa,  0.0%hi,  0.0%si,  0.0%st

Cpu6  : 22.5%us,  1.7%sy,  0.0%ni, 72.5%id,  2.0%wa,  0.7%hi,  0.7%si,  0.0%st

Cpu7  : 39.7%us,  4.7%sy,  0.0%ni, 35.0%id, 15.7%wa,  0.0%hi,  5.0%si,  0.0%st

Mem:   8300692k total,  7877640k used,   423052k free,   272432k buffers

Swap:  5144568k total,      100k used,  5144468k free,  3901936k cached



여기서 


Cpu단위당 설명을 보면,


Cpu0  : 33.3%us,  7.0%sy,  0.0%ni, 55.3%id,  4.3%wa,  0.0%hi,  0.0%si,  0.0%st


33.3%us : 사용자가 사용한 cpu %
7.0%sy : 커널시스템이 사용한 cpu %
0.0%ni : 낮은 우선순위 프로세스에서 사용된 cpu %
80.0%id : cpu idle time %
4.3%wa : cpu 대기시간 %
0.0%hi : 하드웨어 접근 시간 %
0.0%si : 소프트웨어 접근 시간 %
0.0%st : 가상머신이 사용한 시간 %











'Linux' 카테고리의 다른 글

/dev/mapper/VolGroup-lv_root 100%  (0) 2016.02.23
rsync.conf  (0) 2016.02.16
top load average  (0) 2016.02.15
CentOS 7 SVN iptables  (0) 2016.01.29
아파치 리다이렉션 apache url redirection www .htaccess rewrite httpd.conf  (0) 2016.01.25
블로그 이미지

엘로드넷

,

top load average

Linux 2016. 2. 15. 18:15


top - 18:14:25 up 1614 days, 6 min,  3 users,  load average: 4.94, 50.49, 52.42



첫번째 : 4.94 : 과거 1분간 부하 평균

두번째 : 50.49 : 과거 5분간 부하 평균

세번째 : 52.42 : 과거 15분간 부하 평균





'Linux' 카테고리의 다른 글

rsync.conf  (0) 2016.02.16
linux top cpu usage  (0) 2016.02.15
CentOS 7 SVN iptables  (0) 2016.01.29
아파치 리다이렉션 apache url redirection www .htaccess rewrite httpd.conf  (0) 2016.01.25
Linux NFS iptables  (0) 2016.01.19
블로그 이미지

엘로드넷

,

CentOS 7 SVN iptables

Linux 2016. 1. 29. 14:41

iptables -A INPUT -p tcp -m tcp --dport 447 -j ACCEPT

iptables -A INPUT -p tcp -m tcp --dport 3690 -j ACCEPT

블로그 이미지

엘로드넷

,

가. test.com 으로 접속한 것을 www.test.com 으로 리다이렉션하기


1. test.com 도메인 루트에 .htaccess 파일 생성하기


[root@localhost www.test.com]# vi .htaccess


파일 내용은 아래와 같다.


RewriteEngine On

RewriteCond %{HTTP_HOST} !^www.kimhae.com$ [NC]

RewriteRule ^(.*)$ http://www.kimhae.com/$1 [L,R=301]

~                                                       



저장하고 빠져나온다.



2. httpd.conf 설정


 아래 부분에서 AllowOverride None 으로 되어 있는 것을 All 로 변경해 준다.


<Directory "/home/*">

    #

    # Possible values for the Options directive are "None", "All",

    # or any combination of:

    #   Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews

    #

    # Note that "MultiViews" must be named *explicitly* --- "Options All"

    # doesn't give it to you.

    #

    # The Options directive is both complicated and important.  Please see

    # http://httpd.apache.org/docs/2.2/mod/core.html#options

    # for more information.

    #

    Options Indexes FollowSymLinks


    #

    # AllowOverride controls what directives may be placed in .htaccess files.

    # It can be "All", "None", or any combination of the keywords:

    #   Options FileInfo AuthConfig Limit

    #

    AllowOverride All


    #

    # Controls who can get stuff from this server.

    #

    Order allow,deny

    Allow from all


</Directory>



저장하고 나온다.


아파치 재시작


test.com 으로 접속하면 url이 즉시 www.test.com 으로 바뀌는 것을 확인할 수 있다.





나. 반대로 www.test.com 을 test.com 으로 리다이렉션 시킬 경우는 아래와 같이


RewriteEngine On

RewriteCond %{HTTP_HOST} ^www\.test\.com$

RewriteRule ^/?$ "http\:\/\/test\.com\/" [R=301,L]

~                                                       




다. 특정 경로로 리다이렉션 하기


test.com 으로 접속하면 www.test.com/test.php 로 접속하기


RewriteEngine On

RewriteCond %{HTTP_HOST} ^test.com$

RewriteRule ^$ "http://www.test.com/test.php [L,R=301]

~                                                       





라. 다른 도메인으로 리다이렉션하기


test.com 을 www.test2.net 으로


RewriteEngine On

RewriteCond %{HTTP_HOST} !test.com$ [NC]

RewriteRule ^(.*)$ http://www.test2.net/$1 [L,R=301]

~                                                       






끝.








'Linux' 카테고리의 다른 글

top load average  (0) 2016.02.15
CentOS 7 SVN iptables  (0) 2016.01.29
Linux NFS iptables  (0) 2016.01.19
CentOS 7 아파치 2.4.6 한글깨짐 AddDefaultCharset  (0) 2016.01.15
CentOS 7 apache virtualhost  (2) 2016.01.15
블로그 이미지

엘로드넷

,

Linux NFS iptables

Linux 2016. 1. 19. 19:07

NFS Server : 192.168.0.1

NFS Client : 192.168.0.2

NFS Folder : /home/user/session






1. Server (192.168.0.1)


/etc/sysconfig/nfs 파일 수정


#vi /etc/sysconfig/nfs


LOCKD_TCPPORT=32803

# UDP port rpc.lockd should listen on.

LOCKD_UDPPORT=32769


MOUNTD_PORT=892




Server 공유폴더 지정


# vi /etc/exports 


/home/user/session 192.168.0.2(rw,sync,no_root_squash)



nfs시작


# service rpcbind start

# service nfs start




iptables



iptables -A INPUT -s 192.168.0.0/24 -d 192.168.0.0/24 -p udp -m multiport --dport 10053,111,2049,32769,875,892 -m state --state NEW,ESTABLISHED -j ACCEPT


iptables -A INPUT -s 192.168.0 0/24 -d 192.168.0 0/24 -p tcp -m multiport --dport 10053,111,2049,32803,875,892 -m state --state NEW,ESTABLISHED -j ACCEPT









2. Client (192.168.0.2)


/etc/sysconfig/nfs파일 수정


vi /etc/sysconfig/nfs


LOCKD_TCPPORT=32803

# UDP port rpc.lockd should listen on.

LOCKD_UDPPORT=32769


MOUNTD_PORT=892



iptables


iptables -A INPUT -s 192.168.0.0/24 -d 192.168.0 0/24 -p udp -m multiport --sport 10053,111,2049,32769,875,892,32769 -m state --state NEW,ESTABLISHED -j ACCEPT


iptables -A INPUT -s 192.168.0.0/24 -d 192.168.0 0/24 -p tcp -m multiport --sport 10053,111,2049,32803,875,892,32803 -m state --state NEW,ESTABLISHED -j ACCEPT




nfs시작


# service rpcbind start

# service nfs strt





NFS폴더 마움트


# mount -t nfs 192.168.0.1:/home/user/session /home/user/session





NFS 마운트 해제

# umount /home/user/session



NFS 마운트 강제 해제


# umount -f -l /home/user/session








블로그 이미지

엘로드넷

,

httpd 2.4.6 에서 기본 문자셋이 UTF-8 이어서 euc_kr 로 제작된 html에서 한글이 깨진다.


1. httpd.conf 에서 기본을 EUC-KR 으로 변경하고 utf8을 추가해 주기로 한다.



아래와 같이 


AddDefaultCharset EUC-KR

AddCharset UTF-8 .utf8






2. 아파치를 재시작한다.



[root@localhost httpd]# systemctl restart httpd.service





끝.

'Linux' 카테고리의 다른 글

아파치 리다이렉션 apache url redirection www .htaccess rewrite httpd.conf  (0) 2016.01.25
Linux NFS iptables  (0) 2016.01.19
CentOS 7 apache virtualhost  (2) 2016.01.15
CentOS 7 iptables 설정  (1) 2016.01.15
CentOS 7 APM yum 설치 MariaDB  (11) 2016.01.15
블로그 이미지

엘로드넷

,

CentOS 7 apache virtualhost

Linux 2016. 1. 15. 20:03


1. 가상호스트 설정파일을 만든다


[root@localhost conf.d]# vi /etc/httpd/conf.d/vhost.conf



파일 내용은 아래와 같다.



<VirtualHost *:80>


        DocumentRoot /home/testuser/a.test.com

        ServerName a.test.com

        ServerAlias a.test.com

        ErrorLog /var/log/httpd/a.test.com_error.log

        CustomLog /var/log/httpd/a.test.com_access.log combined


</VirtualHost>




2. userdir.conf 에서 testuser 폴더 권한을 지정해 준다.


[root@localhost conf.d]# vi /etc/httpd/conf.d/userdir.conf 



내용 끝에 아래와 같이 추가해 준다.


#

# UserDir: The name of the directory that is appended onto a user's home

# directory if a ~user request is received.

#

# The path to the end user account 'public_html' directory must be

# accessible to the webserver userid.  This usually means that ~userid

# must have permissions of 711, ~userid/public_html must have permissions

# of 755, and documents contained therein must be world-readable.

# Otherwise, the client will only receive a "403 Forbidden" message.

#

<IfModule mod_userdir.c>

    #

    # UserDir is disabled by default since it can confirm the presence

    # of a username on the system (depending on home directory

    # permissions).

    #

    UserDir disabled


    #

    # To enable requests to /~user/ to serve the user's public_html

    # directory, remove the "UserDir disabled" line above, and uncomment

    # the following line instead:

    #

    #UserDir public_html

</IfModule>


#

# Control access to UserDir directories.  The following is an example

# for a site where these directories are restricted to read-only.

#

<Directory "/home/*/public_html">

    AllowOverride FileInfo AuthConfig Limit Indexes

    Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec

    Require method GET POST OPTIONS

</Directory>


<Directory "/home/testuser/*">

        Require all granted

</Directory>

"/etc/httpd/conf.d/userdir.conf" 38L, 1307C




3. 아파치를 재시작한다.


[root@localhost conf.d]# systemctl restart httpd.service





끝.




'Linux' 카테고리의 다른 글

Linux NFS iptables  (0) 2016.01.19
CentOS 7 아파치 2.4.6 한글깨짐 AddDefaultCharset  (0) 2016.01.15
CentOS 7 iptables 설정  (1) 2016.01.15
CentOS 7 APM yum 설치 MariaDB  (11) 2016.01.15
CentOS 7 MySQL-5.7.10 설치 boost  (0) 2016.01.11
블로그 이미지

엘로드넷

,

CentOS 7 iptables 설정

Linux 2016. 1. 15. 13:00

우선 방화벽을 중지한다.

[root@localhost log]# systemctl stop firewalld     

[root@localhost log]# systemctl mask firewalld       



iptables관련 패키지를 설치(업데이트)한다.

[root@localhost log]# yum install iptables-service    



부팅시 시작되도록 한다.

[root@localhost log]# systemctl enable iptables     



iptables 설정파일은 /etc/sysconfig/iptables 이다.


해당 파일을 편집한다.


1. 특정 IP 또는 IP블럭을 거부하고자 할 때,


-A INPUT -s 177.91.82.23 -j DROP

-A INPUT -s 177.91.82.0/24 -j DROP


와 같은 형태로 추가해 준다.



2. 특정 포는 특정 IP 또는 IP블럭에게만 허가하기


-A INPUT -s 192.168.0.0/24 -p tcp --dport 22 -j ACCEPT





iptables 상태확인


[root@localhost log]# systemctl status iptables

iptables.service - IPv4 firewall with iptables

   Loaded: loaded (/usr/lib/systemd/system/iptables.service; enabled; vendor preset: disabled)

   Active: active (exited) since 수 2016-01-13 11:31:40 KST; 1 day 23h ago

  Process: 31836 ExecStop=/usr/libexec/iptables/iptables.init stop (code=exited, status=0/SUCCESS)

  Process: 31903 ExecStart=/usr/libexec/iptables/iptables.init start (code=exited, status=0/SUCCESS)

 Main PID: 31903 (code=exited, status=0/SUCCESS)

   CGroup: /system.slice/iptables.service


 1월 13 11:31:40 localhost.localdomain systemd[1]: Starting IPv4 firewall with iptables...

 1월 13 11:31:40 localhost.localdomain iptables.init[31903]: iptables: Applying firewall rules: [  OK  ]

 1월 13 11:31:40 localhost.localdomain systemd[1]: Started IPv4 firewall with iptables.



iptables 재시작


[root@localhost log]# systemctl restart iptables











'Linux' 카테고리의 다른 글

CentOS 7 아파치 2.4.6 한글깨짐 AddDefaultCharset  (0) 2016.01.15
CentOS 7 apache virtualhost  (2) 2016.01.15
CentOS 7 APM yum 설치 MariaDB  (11) 2016.01.15
CentOS 7 MySQL-5.7.10 설치 boost  (0) 2016.01.11
CentOS 7 network prefix  (0) 2015.12.04
블로그 이미지

엘로드넷

,

php5.6.x대로 올라가면서 소스컴파일시 libmysqlclient_r 관련 에러가 나고 설치가 잘 되지 않는다.

이유인즉 더 이상 번들로 제공되지 않는다는 것인데...


php7로도 시도해 봤지만 결과는 마찬가지다.



결론적으로 yum 을 이용한 설치로 진행하고자 한다.



설치순서는 MySQL5(MariaDB5) > Apache > PHP 이다.


yum으로 MySQL대신에 MariaDB를 설치하기로 한다. MySQL과 명령어는 동일하니깐..



1. mariadb


설치되는 버전은 5.5.44 이다.


[root@Cent7_64B ~]# yum -y install mariadb-server mariadb

[root@Cent7_64B ~]# systemctl start mariadb.service

[root@Cent7_64B ~]# systemctl enable mariadb.service


설치가 되었고 데몬도 시작하였다.


기본 디비와 루트비번을 설정한다.


[root@Cent7_64B ~]# mysql_secure_installation



root 비번 설정 후, 모두 엔터키로 넘어간다.


mariadb 설치 끝


root로 접속되는지 확인해 본다.


[root@Cent7_64B ~]# mysql -u root -p mysql

Enter password: 

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A


Welcome to the MariaDB monitor.  Commands end with ; or \g.

Your MariaDB connection id is 3

Server version: 5.5.44-MariaDB MariaDB Server


Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.


MariaDB [mysql]> 



접속이 된다.




2. Httpd (Apache) 


설치되는 버전은 2.4.6 이다.



[root@Cent7_64B ~]# yum -y install httpd

[root@Cent7_64B ~]# systemctl start httpd.service

[root@Cent7_64B ~]# systemctl enable httpd.service


방화벽 등록

[root@Cent7_64B ~]# firewall-cmd --permanent --zone=public --add-service=http

[root@Cent7_64B ~]# firewall-cmd --permanent --zone=public --add-service=https



직접 zone파일을 수정해도 된다.

[root@Cent7_64B zones]# vi /etc/firewalld/zones/public.xml



등록되어 있는지 확인해 보자.


아래는 public.xml 내용이다.


<?xml version="1.0" encoding="utf-8"?>

<zone>

  <short>Public</short>

  <description>For use in public areas. You do not trust the other computers on networks to not harm your computer. Only selected incoming connections are accepted.</description>

  <service name="dhcpv6-client"/>

  <service name="http"/>

  <service name="ssh"/>

  <service name="https"/>

  <port protocol="tcp" port="3306"/>

</zone>



service에 http와 https가 등록되어 있다.


방화벽을 재시작하여 적용한다.


[root@Cent7_64B zones]# firewall-cmd --reload



브라우저에서 접속해 본다.


아래와 같은 화면이 뜨면 된다.






Document Root 는 /var/www/html 이다.

httpd.conf 파일 위치는 /etc/httpd/conf/httpd.conf 이다.





3. PHP설치


설치되는 버전은 5.4.16 이다.


[root@Cent7_64B conf.d]# yum -y install php



설치 후 아파치를 재시작하면 적용된다.


[root@Cent7_64B conf.d]# systemctl restart httpd.service



phpinfo();  로 확인해 본다.







밑으로 쭉 내려서 모듈들이 설치되었는지 확인해 본다.


iconv, json, libxml, mbstring, mysql, openssl 등등



참고로 설치할 수 있는 php관련 모듈을 검색해 본다.

[root@Cent7_64B conf.d]# yum search php                                                                        

Loaded plugins: fastestmirror

Loading mirror speeds from cached hostfile

 * base: ftp.daumkakao.com

 * epel: mirror.premi.st

 * extras: ftp.daumkakao.com

 * updates: ftp.daumkakao.com

 * webtatic: sp.repo.webtatic.com

================================================================================= N/S matched: php ==================================================================================

geos-php.x86_64 : PHP modules for GEOS

graphviz-php.x86_64 : PHP extension for graphviz

nntpgrab-php.x86_64 : PHP module which allows PHP scripts to communicate with NNTPGrab

php.x86_64 : PHP scripting language for creating dynamic web sites

php-Assetic.noarch : Asset Management for PHP

php-EasyRdf.noarch : A PHP library designed to make it easy to consume and produce RDF

php-EasyRdf-doc.noarch : Documentation for php-EasyRdf

php-Faker.noarch : A PHP library that generates fake data

php-JsonSchema.noarch : PHP implementation of JSON schema

php-Metadata.noarch : A library for class/method/property metadata management in PHP

php-PHPMailer.noarch : PHP email transport class with a lot of features

php-PHPParser.noarch : A PHP parser written in PHP


엄청 많다..



필요한 것들이 설치가 안되어 있으므로 한꺼번에 설치한다.


[root@Cent7_64B conf.d]# yum -y install php-mysql php-gd php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-snmp php-soap curl curl-devel



설치 후 아파치를 재시작한뒤 phpinfo를 확인해 보면 관련 모듈들이 설치되어 있을 것이다.




그동안 소스 설치로 많은 시간이 들었다면 이제는 yum으로 간편하게 설치하자.



끝.


'Linux' 카테고리의 다른 글

CentOS 7 apache virtualhost  (2) 2016.01.15
CentOS 7 iptables 설정  (1) 2016.01.15
CentOS 7 MySQL-5.7.10 설치 boost  (0) 2016.01.11
CentOS 7 network prefix  (0) 2015.12.04
리눅스 NFS설정  (0) 2015.09.25
블로그 이미지

엘로드넷

,




MySQL-5.7.10 설치


1. cmake  가 필요하므로 설치한다



[root@localhost src]# yum -y install cmake






2. boot가 필요하므로 설치한다.


[root@localhost src]# wget http://sourceforge.net/projects/boost/files/boost/1.60.0/boost_1_60_0.tar.gz




압축을 푼다


[root@localhost src]# tar xvfz boost_1_60_0.tar.gz




소스디렉토리로 가서 


bootstrap.sh을 실행한다


[root@localhost boost_1_60_0]#./bootstrap.sh




boost가 설치된 경로를 확인해 본다.


[root@localhost boost_1_60_0]#whereis boost

/usr/include/boost







3. MySQL5.7.10 을 다운받는다.

다운받을 파일 mysql-5.7.10.tar.gz


압축을 푼다.


[root@localhost src]# tar xvfz mysql-5.7.10.tar.gz





4. 소스 디렉토리로 간다.


[root@localhost src]# cd mysql-5.7.10




cmake configure시 아까 확인한 boost경로를 아래와 같이 설정해 준다.


cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DSYSCONFDIR=/etc -DDEFAULT_CHARSET=utf8 -DMYSQL_TCP_PORT=3306 -DWITH_EXTRA_CHARSETS=all -DDEFAULT_COLLATION=utf8_general_ci -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/include/boost


컴파일 한다.


[root@localhost mysql-5.7.10]# make


중략



[ 34%] Building CXX object storage/innobase/CMakeFiles/innobase_embedded.dir/trx/trx0rseg.cc.o

[ 34%] Building CXX object storage/innobase/CMakeFiles/innobase_embedded.dir/trx/trx0sys.cc.o

[ 34%] Building CXX object storage/innobase/CMakeFiles/innobase_embedded.dir/trx/trx0trx.cc.o

[ 34%] Building CXX object storage/innobase/CMakeFiles/innobase_embedded.dir/trx/trx0undo.cc.o



중략







[root@localhost mysql-5.7.10]# make install




초기 데이타베이스 설치 



[root@localhost client]# ./mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data




데몬 구동


[root@localhost client]# /usr/local/mysql/bin/mysqld_safe --user=mysql &




끝.









'Linux' 카테고리의 다른 글

CentOS 7 iptables 설정  (1) 2016.01.15
CentOS 7 APM yum 설치 MariaDB  (11) 2016.01.15
CentOS 7 network prefix  (0) 2015.12.04
리눅스 NFS설정  (0) 2015.09.25
CentOS 7 apm 소스설치, 방화벽 적용  (4) 2015.07.23
블로그 이미지

엘로드넷

,