分類存檔:虛擬應用

健伍點解要租用 VPS 虛擬專用伺服器

健伍現在使用 SERVER 其實都是 VPS , 但這個 VPS 是自己買了一部二手電腦安裝了 proxmox 放在一個朋友租的 “數據中心” 櫃子內 .

但經濟下行的情況下 , 有可能不會再租用 , 所以要想想把伺服器搬回家中了 .

家中的寬頻 IP 會隨時轉變的 , 所以 “kenng.hk” 的 域名要如何對應 IP 的轉變 .

方法一 . 把 “域名” 放在有 “域名寄存” 的公司 , 把域名指向 Dynamic DNS ( 例子: 把 www.kenng.hk CNAME 到 noip , duckdns , dyndns , ddns 等公司 , 再用這些公司來 update 家中 隨時會變的 IP 地址 )

方法二. 自己建造一個能 dynamic update ip 的 DNS server

老實講 “方法一” 應該是最平的做法 ^_^ 當然我選用了 方法二 , 不然這編文章都不會出現

好了首先要找一間最平最平的 VPS 供應商了 , 我在網上找了一找 , 以下是我睇過的文章, 在這裏提供給大家參考一下

https://www.lifetat.com/vps-hosting-分享和比較/ , https://www.10besty.com/best-vps-hosting-services/#three , https://progressbar.tw/posts/131

我的目標要找最平又相對稳定的 VPS , 一般 1G RAM 的 VPS 大約要 5美元一個月 , 一年大約港幣 HKD480 左右吧 , 但我自己選了一個 15美元一年的 openvz server , 但這個 server ram 只有 128MB RAM , 如果只是運行 DNS server 就卓卓有餘了 .

我用的是 RAMNODE 公司提供的服務 https://www.ramnode.com/

買一個 128MB SVZ , 虛擬機有 1CPU , 12GB SSD , 1Gbps Port , 500GB Bandwidth , 1 IPv4 , 系統我就選用了 Ubuntu 20.04 , 選擇了 LA ( 洛杉磯 ) 本來想放在 NYC ( 紐約 ) 但沒有貨了

付了錢就可以開始使用了, 本身部機已經裝好了基本的軟件, bind9 , apache , exim , sshd

不知道是不是我用了 ubuntu os , 用不了 html 5 serial console

我用 putty ssh 去新 server , 我個人建議有興趣買個 VPS 試東西的朋友 , 最好修改一下 ssh port 會好一點 , 在 internet 世界有著很多 爬蟲 不斷試你的電腦 22 port

下一章會介紹下一設定 dynamic dns server 方法

今次試的東西是 docker , 類似virtual machine, 又好像 沙盒

今次我要試的是 DOCKER , 點解要試這個 ? 因為有公司舊的網頁要用 PHP 5.x 同時又要 PHP 7.x 雖然好多方法去實現同時運行多個 PHP VERSION , 但是一個好機會試吓新東西

在文章最後有我參考過的網站文章連結

大家先去了解什麼是 DOCKER
參考網址 : https://philipzheng.gitbooks.io/docker_practice/content/

好了大家了解都差不多了 , 那我們開始吧 !
我用的是 ubuntu , 所以以下 command 都是 debian apt

apt update
apt upgrade
apt install gnupg2
apt install curl
apt install software-properties-common
curl -fsSL
https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add –
add-apt-repository “deb [arch=amd64]
https://download.docker.com/linux/ubuntu $(cat /etc/os-release | grep
UBUNTU_CODENAME | cut -d ‘=’ -f 2) stable”
apt update
apt install docker-ce

好了安裝完, 立即試一試, hello-world docker 有什麼反應先

root@docker-test:~#
docker run hello-world
Unable to find image ‘hello-world:latest’ locally
latest: Pulling from library/hello-world
1b930d010525: Pull complete
Digest:
sha256:fc6a51919cfeb2e6763f62b6d9e8815acbf7cd2e476ea353743570610737b752
Status: Downloaded newer image for hello-world:latest

Hello from Docker!
This message shows that your installation appears to be working
correctly.

To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the “hello-world” image from the
Docker Hub.
(amd64)
3. The Docker daemon created a new container from that image
which runs the
executable that produces the output you
are currently reading.
4. The Docker daemon streamed that output to the Docker
client, which sent it
to your terminal.

To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash

Share images, automate workflows, and more with a free Docker ID:
https://hub.docker.com/

For more examples and ideas, visit:
https://docs.docker.com/get-started/

root@docker-test:~#

當你行 docker run hello-world
它會自動上到 “倉庫” 找 “hello-world” 這個影像檔然後執行

之後我們再試下 ubuntu shell 看看

docker run -it ubuntu bash

root@docker-test:~#
docker run -it ubuntu bash
Unable to find image ‘ubuntu:latest’ locally
latest: Pulling from library/ubuntu
423ae2b273f4: Pull complete
de83a2304fa1: Pull complete
f9a83bce3af0: Pull complete
b6b53be908de: Pull complete
Digest:
sha256:04d48df82c938587820d7b6006f5071dbbffceb7ca01d2814f81857c631d44df
Status: Downloaded newer image for ubuntu:latest
root@7b55e3f631cd:/#

這個 shell 是在 ubuntu image 內執行的 , “7b55e3f631cd” 就是 docker 生成的 ubuntu 容器內裏就是一個 ubuntu

root@7b55e3f631cd:/#
ls -la
total 72
drwxr-xr-x 1 root root 4096 Feb 24 07:43 .
drwxr-xr-x 1 root root 4096 Feb 24 07:43 ..
-rwxr-xr-x 1 root root 0 Feb
24 07:43 .dockerenv
drwxr-xr-x 2 root root 4096 Feb 19 01:17 bin
drwxr-xr-x 2 root root 4096 Apr 24 2018 boot
drwxr-xr-x 5 root root 360 Feb 24 07:43 dev
drwxr-xr-x 1 root root 4096 Feb 24 07:43 etc
drwxr-xr-x 2 root root 4096 Apr 24 2018 home
drwxr-xr-x 8 root root 4096 May 23 2017 lib
drwxr-xr-x 2 root root 4096 Feb 19 01:15 lib64
drwxr-xr-x 2 root root 4096 Feb 19 01:14 media
drwxr-xr-x 2 root root 4096 Feb 19 01:14 mnt
drwxr-xr-x 2 root root 4096 Feb 19 01:14 opt
dr-xr-xr-x 392 nobody nogroup 0 Feb 24
07:43 proc
drwx—— 2 root root 4096 Feb 19 01:17 root
drwxr-xr-x 1 root root 4096 Feb 21 22:20 run
drwxr-xr-x 1 root root 4096 Feb 21 22:20 sbin
drwxr-xr-x 2 root root 4096 Feb 19 01:14 srv
dr-xr-xr-x 13 nobody nogroup 0
Feb 20 03:34 sys
drwxrwxrwt 2 root root 4096 Feb 19 01:17 tmp
drwxr-xr-x 1 root root 4096 Feb 19 01:14 usr
drwxr-xr-x 1 root root 4096 Feb 19 01:17 var
root@7b55e3f631cd:/#

其實概念就 docker 生成一個可讀寫的容器 , 把 image 投射內其中, 你在這個容器做的東西不會影響 image 內的資料 ,
image 是唯讀的 !

每個 docker 生成的容器都是獨立 , 容器究竟是什麼 , 如果你知道有些掃毒程式會創造 “沙盒” 來測試那些行檔是否中毒 !

沙盒的概述可以看看這些網址
https://www.arthurtoday.com/2011/06/sandbox.html
http://www.pcdiy.com.tw/detail/11605

同樣 docker 生成的容器就算被入侵 , 基本上都不會影響主機 !

我們試一試裝個 apche , 先看看有那些 image 可以用先

用command “docker search apache” 找找有什麼 image 可用

root@docker-test:~#
docker search apache
NAME DESCRIPTION STARS OFFICIAL AUTOMATED
httpd The Apache HTTP Server
Project 2869 [OK]
tomcat Apache Tomcat is an open source
implementati… 2645 [OK]
cassandra Apache Cassandra is an open-source
distribut… 1092 [OK]
maven Apache Maven is a software project
managemen… 983 [OK]
solr Solr is the popular, blazing-fast, open
sour… 729 [OK]
apache/nifi Unofficial convenience binaries and Docker
i… 161 [OK]
eboraas/apache-php PHP on Apache (with SSL/TLS support), built
… 143 [OK]
apache/zeppelin Apache
Zeppelin 117 [OK]
eboraas/apache Apache (with SSL/TLS support), built on
Debi… 91 [OK]
apache/airflow Apache
Airflow 87
groovy Apache Groovy is a multi-faceted language
fo… 85 [OK]
nimmis/apache-php5 This is docker images of Ubuntu 14.04 LTS
wi… 61 [OK]
apacheignite/ignite Apache Ignite In-Memory docker
image. 60 [OK]
bitnami/apache Bitnami Apache Docker
Image 58 [OK]
linuxserver/apache An Apache container, brought to you by
Linux… 25
apachepulsar/pulsar Apache Pulsar – Distributed pub/sub
messagin… 22
apache/nutch Apache
Nutch 21 [OK]
antage/apache2-php5 Docker image for running Apache 2.x with
PHP… 16 [OK]
webdevops/apache Apache
container 14 [OK]
newdeveloper/apache-php apache-php7.2 5
lephare/apache Apache
container 5 [OK]
newdeveloper/apache-php-composer apache-php-composer 4
secoresearch/apache-varnish Apache+PHP+Varnish5.0 2 [OK]
oberonamsterdam/apache24-fpm Default Oberon apache setup using PHP-FPM,
r… 1 [OK]
jelastic/apachephp An image of the Apache PHP application
serve… 0
root@docker-test:~#

有數十個 image 可用 , 有些包含 tomcat , 有些包含 php , 看看你想用那一個 !

我們就用第一個 image “httpd” , 下載這個 image 執行 “docker pull httpd”

root@docker-test:~#
docker pull httpd
Using default tag: latest
latest: Pulling from library/httpd
bc51dd8edc1b: Pull complete
dca5bc65e18f: Pull complete
ccac3445152a: Pull complete
8515f2015fbc: Pull complete
e35494488b8c: Pull complete
Digest:
sha256:b783a610e75380aa152dd855a18368ea2f3becb5129d0541e2ec8b662cbd8afb
Status: Downloaded newer image for httpd:latest
docker.io/library/httpd:latest
root@docker-test:~#

下載完成, 我們看看現在我們有多少個可用的 image 先 , 執行 ” docker images”

root@docker-test:~#
docker images


REPOSITORY
TAG IMAGE
ID CREATED SIZE


ubuntu
latest 72300a873c2c 2 days
ago 64.2MB


httpd
latest c562eeace183 3 weeks
ago 165MB


hello-world
latest fce289e99eb9 13 months
ago 1.84kB


root@docker-test:~#

我們已經有三個 image , 先前測試用的 “hello-world” & “ubuntu” , 還有剛下載的 “httpd”

好了急不及待, 我們來創造一個 docker 環境行 apache 吧 !

root@docker-test:~#
docker run -d –name=apache2 httpd
2d40f50299972e46392d10b9ecf8afbbe3189cace34aaadede7d1e372509b667

已經生成了一個基於 httpd image 的容器 “–name” 給予這個容器一個別名

當前有多少容器在運行 command : “dcoker ps -a”

root@docker-test:~#
docker ps -a
CONTAINER
ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2d40f5029997 httpd “httpd-foreground” 13 minutes
ago Up 13
minutes 80/tcp apache2
7b55e3f631cd ubuntu “bash” 58 minutes ago Exited
(127) 52 minutes
ago elastic_morse
a8560ebcedb9 hello-world “/hello” About an hour ago Exited (0)
About an hour
ago distracted_dubinsky

你們可以看到 status 只有 apache2 在背環繼續執行 , 因為我創造apache容器時加了 “-d” daemon

要停止那些容器 command : docker stop apache2

root@docker-test:~#
docker stop apache2
apache2
root@docker-test:~# docker ps -a
CONTAINER
ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2d40f5029997 httpd “httpd-foreground” 20 minutes
ago Exited (0)
5 seconds
ago apache2
7b55e3f631cd ubuntu “bash” About an hour ago Exited
(127) About an hour
ago elastic_morse
a8560ebcedb9 hello-world “/hello” About an hour ago Exited (0)
About an hour
ago distracted_dubinsky

你看到 status 已經停止了 , 可以用 “docker start apache2” 或 “docker restart
apache2” 把容器重新運行

root@docker-test:~#
docker start apache2
apache2
root@docker-test:~# docker ps -a
CONTAINER
ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2d40f5029997 httpd “httpd-foreground” 23 minutes
ago Up 2
seconds 80/tcp apache2
7b55e3f631cd ubuntu “bash” About an hour ago Exited
(127) About an hour
ago elastic_morse
a8560ebcedb9 hello-world “/hello” About an hour ago Exited (0)
About an hour
ago distracted_dubinsky

如果要完全移除這個容器,先停止這個容器再執行 command : docker rm apache2

root@docker-test:~#
docker rm apache2
Error response from daemon:
You cannot remove a running container
2d40f50299972e46392d10b9ecf8afbbe3189cace34aaadede7d1e372509b667. Stop
the container before attempting removal or force remove
root@docker-test:~# docker stop apache2
apache2
root@docker-test:~# docker rm apache2
apache2
root@docker-test:~# docker ps -a
CONTAINER
ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7b55e3f631cd ubuntu “bash” About an hour ago Exited
(127) About an hour
ago elastic_morse
a8560ebcedb9 hello-world “/hello” About an hour ago Exited (0)
About an hour
ago distracted_dubinsky
root@docker-test:~#

看到沒有已經移除了 apache2 這容器了 !

好了講了這麼多要點樣 config 這個容器內 apache config 呢?

我們先入去這個容器看看 ! 這個容器是個 linux 所以要linux shell 入去 !

參考網址 : https://www.runoob.com/docker/docker-exec-command.html

command : docker exec -it apache2 bash
就是在 apache2 容器行 bash shell

root@docker-test:~#
docker exec -it apache2 bash
root@48c49e4b63a3:/usr/local/apache2#

已經取得 apache 容器 bash shell 了

root@48c49e4b63a3:/usr/local/apache2#
ls -la
total 56
drwxr-xr-x 1 www-data www-data 4096 Feb 2 00:15 .
drwxr-xr-x 1 root root 4096 Feb 2 00:12
..
drwxr-xr-x 2 root root 4096 Feb 2 00:15
bin
drwxr-xr-x 2 root root 4096 Feb 2 00:15
build
drwxr-xr-x 2 root root 4096 Feb 2 00:15
cgi-bin
drwxr-xr-x 4 root root 4096 Feb 2 00:15
conf
drwxr-xr-x 3 root root 4096 Feb 2 00:15
error
drwxr-xr-x 2 root root 4096 Feb 2 00:15
htdocs
drwxr-xr-x 3 root root 4096 Feb 2 00:15
icons
drwxr-xr-x 2 root root 4096 Feb 2 00:15
include
drwxr-xr-x 1 root root 4096 Feb 24 08:55 logs
drwxr-xr-x 2 root root 4096 Feb 2 00:15
modules

這個 image 裝了 apache location 是 /usr/local/apache2 , 我們要的 apache config 就在 conf folder 內 !

直接修改這個 conf 是可以的, 但不要忘記如果容器移除了, 資料一同移除 . 那麼如何保存這些資料 ?

你可以把當前修改過的容器 , SAVE 成新的 image 使用 , 但我們今次用的是 “資料卷”
https://philipzheng.gitbooks.io/docker_practice/content/data_management/volume.html

我們現在把容器內的 apache conf folder copy 到實體機某 folder 進行修改及以資料卷的方式掛入 apache2 容器內

root@48c49e4b63a3:/usr/local/apache2/conf#
ls -la
total 120
drwxr-xr-x 4 root root 4096
Feb 2 00:15 .
drwxr-xr-x 1 www-data www-data 4096 Feb 2 00:15 ..
drwxr-xr-x 2 root root 4096
Feb 2 00:15 extra
-rw-r–r– 1 root root 20823 Feb 2
00:15 httpd.conf
-rw-r–r– 1 root root 13064 Feb 2
00:15 magic
-rw-r–r– 1 root root 60847 Feb 2
00:15 mime.types
drwxr-xr-x 3 root root 4096
Feb 2 00:15 original
root@48c49e4b63a3:/usr/local/apache2/conf# exit
exit
root@docker-test:~# docker cp apache2:/usr/local/apache2/conf
/opt/docker-apache2-conf/
root@docker-test:~# ls -l /opt/docker-apache2-conf/conf/
extra/ httpd.conf magic mime.types original/
root@docker-test:~# ls -l /opt/docker-apache2-conf/conf/

把apache2容器內/usr/local/apache2/conf 抄到實體機 /opt/docker-apache2-conf/

我們先把容器停了及移除重新創造一個用資料卷的apche2容器

root@docker-test:/opt/docker-apache2-conf#
docker stop apache2
apache2
root@docker-test:/opt/docker-apache2-conf# docker rm apache2
apache2
root@docker-test:/opt/docker-apache2-conf#
docker run -d –name=apache2 -v
/opt/docker-apache2-conf/conf:/usr/local/apache2/conf   -v
/opt/docker-apache2-conf/html:/var/www httpd
52af877f4a8fbd927f3a8fea9e3568e3d8ee317f03f2a6e22f82cc083a8c670f

解釋一下
-v /opt/docker-apache2-conf/conf:/usr/local/apache2/conf
-v /opt/docker-apache2-conf/html:/var/www

用 -v 就是資料卷的意思
主機 folder “/opt/docker-apache2-conf/conf” 投射入容器
“/usr/local/apache2/conf” folder
主機 folder “/opt/docker-apache2-conf/html” 投射入容器 “/var/www” folder

一切都OK 了 , 但問題來了 ? 如何把主機的 listing port 投射入容器

我們就要用 -p 8081:80

List containers

root@docker-test:/opt/docker-apache2-conf# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
52af877f4a8f httpd “httpd-foreground” 8 minutes
ago Up 8
minutes 80/tcp apache2
7b55e3f631cd ubuntu “bash” 2 hours
ago Exited
(127) 2 hours
ago elastic_morse
a8560ebcedb9 hello-world “/hello” 2 hours
ago Exited (0)
2 hours
ago distracted_dubinsky
root@docker-test:/opt/docker-apache2-conf# docker stop apache2
apache2
root@docker-test:/opt/docker-apache2-conf# docker rm apache2
apache2
root@docker-test:/opt/docker-apache2-conf#
docker run -d –name=apache2 -p 8081:80 -v
/opt/docker-apache2-conf/conf:/usr/local/apache2/conf   -v
/opt/docker-apache2-conf/html:/var/www httpd
0995c2a40a9be6643f67df8db6664ffae4fea7022261190f08d732d23715f0b7
root@docker-test:/opt/docker-apache2-conf# docker ps -a
CONTAINER
ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0995c2a40a9b httpd “httpd-foreground” 30 seconds
ago Up 27
seconds 0.0.0.0:8081->80/tcp apache2
7b55e3f631cd ubuntu “bash” 2 hours
ago Exited
(127) 2 hours
ago elastic_morse
a8560ebcedb9 hello-world “/hello” 2 hours
ago Exited (0)
2 hours
ago distracted_dubinsky
root@docker-test:/opt/docker-apache2-conf#

看到 status 主機 8081 port 投射到 容器的 80 port 了

那就是外部連接主機的port 8081 就會 容器apache2 提供服務 http://xx.xx.xx.xx:8081/

我參考過的網址

https://blog.basec.cc/index.php/archives/65/
https://github.com/acmesh-official/acme.sh/wiki/Run-acme.sh-in-docker
https://www.jianshu.com/p/ea4a00c6c21c
https://www.iszy.cc/2019/02/13/docker-acme-sh/
https://segmentfault.com/a/1190000012063374
https://blog.chengweichen.com/2015/05/docker-nginx-php-fpm-52-mysql.html
https://my.oschina.net/u/3375733/blog/1591091
https://beginor.github.io/2017/06/08/use-compose-instead-of-run.html
https://zhuanlan.zhihu.com/p/45425683

ImDisk Toolkit 軟件

今次介紹ImDisk用來做什麼的呢?

ImDisk在創建物理內存/虛擬內存重疊還是很容易的,加載ISO副本也沒有問題,如果你想把數據放在內存裡,那還是要折騰一下的。

因為ImDisk虛擬的內存硬盤重新啟動後就會消失,所以就需要批處理來自動解決這個問題,大致思路是讓ImDisk自啟動並加載虛擬磁盤,如果是存放臨
時數據,那麼關機的時候就不用管 了,因為數據不要了。

先去下載 imdisk URL = https://sourceforge.net/projects/imdisk-toolkit/

製作 Ram driver

可以掛載 ISO , Virtual HD , Virtual floppy 等等….