2016年6月28日 星期二

Web server架設

首先先安裝所需套件:

 #yum -y install httpd

接下來是啟動web server服務:

#systemctl enable httpd.service
#systemctl start httpd.service
#systemctl status httpd.service

開通防火牆:

#firewall-cmd --permanent --add-service=http
#firewall-cmd --reload

再安裝PHP模組:

#yum -y install php-* --skip-broken php-mysql

重新啟動Web server服務:

#systemctl restart httpd.service

在 /etc/httpd/conf.d目錄中自由新增檔案:

#cd /etc/httpd/conf.d

新增vhosts.conf檔案:

#vim vhosts.conf

<VirtualHost _default_:80>
   ServerName www.example.com
   DocumentRoot /var/www/html
</VirtualHost>
<VirtualHost *:80>
   ServerName test1.example.com
   DocumentRoot /var/www/vhosts/test1
</VirtualHost>

建立虛擬網路目錄:

#mkdir -p /var/www/vhosts/test1

建立虛擬網頁:

#vim /var/www/vhosts/test1/index.html

Hello!! Test1 Web Site !!

新增DNS紀錄:

#vim /var/named/example.zone


$TTL 10
@        IN SOA dns1.example.com. root (
         2016032901;
         1H;
         2D;
         3W;
         10 )
@        IN NS dns1.example.com.
@        IN A 192.168.5.220
@        IN MX 10 mail

dns1.example.com. IN A 192.168.5.220
mail                         IN A 192.168.5.220
ftp                            IN A 192.168.5.220
www                        IN A 192.168.5.220
test1                         IN  A  192.168.5.220     //新增在最後一行

重新啟動DNS服務:

#systemctl restart named

重新啟動Web server服務:

#systemctl restart httpd





2016年6月26日 星期日

Proftpd server

首先先安裝EPEL套件:
#rpm -ivh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

安裝 proftpd 相關套件:
#yum install -y proftpd-*

開啟防火牆:
#firewall-cmd --permanent --add-service=ftp

#firewall-cmd --reload

啟動與執行proftpd:
#systemctl enable proftpd.service

#systemctl start proftpd

取消與關閉proftpd:
#systemctl disable proftpd.service

#systemctl stop proftpd

重新執行proftpd:
#systemctl restart proftpd




之後打開瀏覽器打上ftp://192.168.XXX.XXX ,登入之後就會看到你的站台目錄了

2016年6月16日 星期四

arduino自走車

今天心血來潮來做自走車,今天是做用序列窗控制馬達正反轉及轉速的實驗

程式碼如下:
const int M1_enable = 5;  //定義腳位
const int M2_enable = 6;
const int M1_int1 = 12;
const int M1_int2 = 11;
const int M2_int3 = 10;
const int M2_int4 =  9;
int speed = 0;
void setup() {
Serial.begin(9600);     //將狀態顯示在序列窗上
pinMode(M1_int1, OUTPUT);   //設定pin腳為輸出
pinMode(M1_int2, OUTPUT);
pinMode(M2_int3, OUTPUT);
pinMode(M2_int4, OUTPUT);
Serial. println(" '+':speed up   '-':speed down   'F':forward,  'B':backward,  others:Stop");  //指令設定
}

void loop() {
  int _speed;

if (Serial. available()) {
  char ch = Serial.read();
if (ch=='+') {
  speed ++;
 if (speed>10) speed=10;
 _speed =map(speed, 1, 10, 60,  255);

 Serial.print("speed , _speed=> "); Serial.print(speed); Serial.print(" , ");
 Serial.println(_speed);
 analogWrite(M1_enable, _speed);
 analogWrite(M2_enable, _speed);
} else if (ch== '-'){
  speed--;
 if (speed<=0){
  speed=0;
  _speed=0;
 } else {
 _speed = map(speed, 1, 10,  60, 255);
 }

 Serial.print("speed , _speed=>");
 Serial.print(speed);
 Serial.print( " , ");
 Serial.print(_speed);
 analogWrite(M1_enable, _speed);
 analogWrite(M2_enable, _speed);
 } else if (ch== 'F') {
 
Serial.println("forward");
   digitalWrite(M1_int1, HIGH);  //right正轉
   digitalWrite(M1_int2, LOW);
   digitalWrite(M2_int3, HIGH);  //lift正轉
   digitalWrite(M2_int4,  LOW );
 } else if (ch=='B') {

 Serial.println("backward");
   digitalWrite(M1_int1, LOW);  //right反轉
   digitalWrite(M1_int2, HIGH);
   digitalWrite(M2_int3, LOW);  //lift反轉
   digitalWrite(M2_int4, HIGH);
  }else {
 
 Serial.println("Stop" );
    speed=0;
    analogWrite(M1_enable, speed);
    analogWrite(M2_enable, speed);
  }
}
}




序列窗畫面























載入後執行序列窗就會這樣,當下達  F 的指令就是前進但此時的轉速是0,因此還要在下 轉速從0變為60,在按 會依序增加20直到255極限, B 是倒退, 一樣按 + 增加轉速;相反按  - 是降速
O 是停止的意思

2016年6月6日 星期一

Llinux RAID5(2016/6/7)

Linux RAID製作:
設定目標: mdadm 來建立磁碟陣列

設置環境:CPU:  I7  2600
                 memory:  4G
                OS:  CentOS7

設定流程:

首先先安裝mdadm公用程式
      # yum install mdadm


磁碟分割幾個區塊:
# gdisk  /dev/sda
Welcome to fdisk (util-linux 2.23.2).

Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

命令 (m 以獲得說明):n   //新增磁區

Select (default e):  p      //主要分割區

Selected partition 4

起初 sector (29698048-42150143, 預設 29698048):      //這邊我直接enter下去
最後 sector, +sectors 或 +大小{K,M,G} (29698048-42150143, 預設 42150143):  //enter

command (m for help): t    //指定磁區格式
Hex code (type L to list codes):fd
# fd =Linux raid autodetect     //按下[I]即可選擇需要的格式

command (m for help):w      //w=寫入分割表
The partition table has been altered!
Calling ioctl() to re-read partition table.
Syncing disks.     //六顆硬碟都照以上這些步驟做


# mdadm -C /dev/mda0  --level=raid5 --devices=6 /dev/sda1/dev/sdb1/dev/sdc1/dev/sde1

/dev/sdf1/dev/sdg1



製作心得: 一開始我們很努力在找主題來做,但似乎不太順利,一直處於繞圈圈的狀態下,但後來還是來做RAID5 ,情況就有比較好一點,雖然我們中間有很多問題存在,比如說:mdadm的公用程式不能安裝、分割後卻沒有辦法進行下一步驟......   我們就一直找可行的教學,找得很辛苦一直都找不到差點就想放棄,後來終於被我們給找到了,完成之後雖然我們很多不懂的東西,但堅持下去也是做的了事的,所以心態的調整也是成功的條件之一。 (2016/06/15) 








參考文獻資料:
              http://www.tecmint.com/create-raid-5-in-linux/
http://paul.pixnet.net/blog/post/5757945-%5B%E7%AD%86%E8%A8%98%5Dlinux-               %E8%BB%9F%E9%AB%94-raid-5-%E5%AF%A6%E4%BD%9C

                          


2016年5月30日 星期一

linux mySQL專題製作


目前先預定主題是mySQL server,目標的話還要等找到更多資料才能確定



更新:現在發現做SQL server為主題 好像走到死胡同,所以又再找題材~~

2016年4月6日 星期三

E-MAIL SERVER架設(2016/04/06)

E-MAIL SERVER架設雖然有弄完,可是郵件傳不出去一直顯示removed,因此後面就沒有辦法在做下去囉~


首先一樣要安裝Postfix套件:#yum -y install postfix dovecot

編修目錄檔:
#vim /etc/postfix/main.cf
myhostname = mail.example.com
mydomain = example.com
myorigin = $mydomain
mynetworks_style = class
mynetworks = 127.0.0.0/8, 192.168.100.0/24(打本機網段即可)

inet_interfaces = all
mydestination = $mydomain, $myhostname, localhost.$mydomain, localhost
mail_spool_directory = /var/mail

home_mailbox = Maildir/
mailbox_size_limit = 0  #原設定參數沒有
message_size_limit = 0  #請自己加上即可
換編修這個目錄檔:
#vim /etc/dovecot/dovecot.conf
protocols = imap pop3
編修設定檔: 
#vim /etc/dovecot/conf.d/10-mail.conf
mail_location = mbox:~/mail:INBOX=/var/mail/%u

開啟防火牆服務:
#firewall-cmd --permanent --add-service=smtp
#firewall-cmd --permanent --add-port=110/tcp
#firewall-cmd --permanent --add-port=143/tcp
#firewall-cmd --reload
設定 SELinux :
#setsebool -P postfix_local_write_mail_spool on

啟動 smtp 與 imap 的服務:
#systemctl enable postfix
#systemctl enable dovecot
#systemctl start postfix
#systemctl start dovecot
檢測mail可否發送出去(我就是掛在這邊XD):
#mail student@mail.example.com
Subject:  test
Hello World!
.(PS "."是結束的意思)
查看一下的記錄:
#tail /var/log/maillog

DNS SERVER 架設(2016/04/06)

今天大約做完兩個SERVER的架設,因為做的過程中有點錯誤所以只做了兩個站台架設

這是DNS SERVER架設

首先:
先要安裝bind套件:#yum -y install bind bind-libs bind-chroot bind-utils

接下來要編修目錄檔:#vim /etc/named.conf
options {
        listen-on port 53  { any; };
        //listen-on-v6 port 53 { ::1; };(該行把它註解掉)
        directory          "/var/named";
        dump-file          "/var/named/data/cache_dump.db";
        statistics-file    "/var/named/data/named_stats.txt";
        memstatistics-file "/var/named/data/named_mem_stats.txt";
        allow-query        { localhost; 192.168.100.0/24; };
        recursion yes;                 (上面打自己本機的ip網段)

        dnssec-enable yes;
        dnssec-validation yes;
        dnssec-lookaside auto;
        bindkeys-file "/etc/named.iscdlv.key";

        managed-keys-directory "/var/named/dynamic";

        pid-file "/run/named/named.pid";
        session-keyfile "/run/named/session.key";
};

logging {
        channel default_debug {
           file "data/named.run";
           severity dynamic;
        };
};

include "/etc/named.rfc1912.zones";
include "/etc/named.root.key";

zone "." IN {
        type hint;
        file "named.ca";
};
//設定所管轄的網域名稱對IP正解析
zone "example.com" IN {
        type master;
        file "example.zone";
};
//設定所管轄的網域名稱對IPv4反解析
zone "100.168.192.in-addr.arpa" IN {
        type master;
        file "example.reverse";
};

接下來換編修這個目錄檔:
#vim /var/named/example.zone
$TTL 10
@        IN SOA dns1.example.com. root (
         2016032901;
         1H;
         2D;
         3W;
         10 )
@        IN NS dns1.example.com.
@        IN A 192.168.XXX.XXX
@        IN MX 10 mail

dns1.example.com. IN A 192.168.XXX.XXX(本機IP位置)
mail              IN A 192.168.XXX.XXX(本機IP位置)
ftp               IN A 192.168.XXX.XXX(本機IP位置)
www               IN A 192.168.XXX.XXX(本機IP位置)
接下來要編修另一個目錄檔:
#vim /var/named/example.reverse
$TTL 10
@        IN SOA dns1.example.com. root (
         2016032901;
         1H;
         2D;
         3W;
         10 )
@        IN NS dns1.example.com.
xxx      IN PTR dns1.example.com.
xxx      IN PTR mail.example.com.
xxx      IN PTR www.example.com.
xxx      IN PTR ftp.example.com. 
(ps xxx為ip後三碼)
接下來開啟防火牆設定:
#firewall-cmd --permanent --add-service=dns
#firewall-cmd --reload
啟動DNS SERVER的服務:
#systemctl stop named
#systemctl disable named
#systemctl enable named-chroot
#systemctl start named-chroot
接ㄒ來是設定本機查詢的DNS SERVER:
#vim /etc/resolv.conf
search example.com
nameserver 192.168.100.183
下面是一些檢測工具:
#dig example.com NS
#dig example.com A
#dig -x 192.168.XXX.XXX

2016年3月29日 星期二

samba server 架設2016/3/30

今天我們所上的課程是samba server的架設一開始當然是要安裝samba的套件才能使用啦~~
    
安裝指令:#yum -y install samba
      設定想分享的目錄 :#mkdir /sharedpath

設定SELinux限定規則:
      #semanage fcontext -a -t samba_share_t '/sharedpath(/.*)?'            
      #restorecon -RFvv /sharedpath

設定samba server的設定檔:
#vim /etc/samba/smb.conf
 [global]
   workgroup = WORKGROUP
   interfaces = lo eth0 192.168.1.1/24
   hosts allow = 127. 192.168.1.
  [myshare]
  path = /sharedpath
  writable = no
  valid users = fred, @management

開啟 SELinux 存取規則: #setsebool -P samba_enable_home_dirs=on
                                          #restorecon -RFvv /sharedpat
在 Samba Server 上,検查設定項目是否正確: #testparm
在 Samba Server 上,新增一般的使用者帳號與密碼:
#useradd -s /sbin/nologin fred
在 Samba Server 上,安裝管理使用者的套件:
#yum -y install samba-client
在 Samba Server 上,設定可存取 Samba Server的使用者帳號與密碼:
#smbpasswd -a fred
啟動 Samba Server:
#systemctl start smb nmb
#systemctl enable smb nmb
在 Samba Server 上,開啟防火牆設定:
#firewall-cmd --permanent --add-service=samba
#firewall-cmd --reload
在 client 端,掛載 Samba Server 所分享目錄:
#mkdir /mnt/myshare
#mount -t cifs -o username=fred //server/myshare /mnt/myshare

linux FTP及NFS站台架設 2016/3/29

今天我們教了linux 的站台架設,一開始我們現要安裝ftp及nfs的套件

nfs套件安裝指令:  #yum -y install nfs-utils  

接下來就是啟動nfs: #systemctl start nfs-server.service
                       #systemctl enable nfs-server.service

防火牆的開啟: #firewall-cmd --permanent --add-service=nfs
                #firewall-cmd --reload

建立根目錄: #mkdir /myshare

設定分享目錄的權限:#vim /etc/exports/myshare  *.example.com(rw) 10.0.0.0/8(ro)

在 NFS Server 上,發佈分享目錄:#exportfs -r

在 NFS Server 上,啟動 SELiux 放行規定: #setsebool -P nfs_export_all_rw on
                                                                            #setsebool -P nfs_export_all_ro on

在 NFS Server 上,查詢分享狀態:#showmount -e

在 client 端,掛載 NFS Server 所分享目錄: #mkdir /mnt/nfsshare
                                      #mount -t nfs server(ps:請打自己的本機ip位置):/myshare /mnt/nfsshare

參考文獻資料:http://linux.onlinedoc.tw/search/label/Server%3A%3ANFS%20Server