Feb 20, 2020
TechnologyRecently I find it’s necessary to re-orgnize my blog structure, for past 8
years I’ve written nearly 1000 articles in this blog, they covered so many
technologies, from embedded system to cloud-computing, also with my life’s
blog. So I simply use Technology
and Life
for classifying them. Also I
have to adjust my websiste’s compatibility to newest hugo(v0.64.0), previously
I use an old version(v0.31.0) for building the whole website. Following
are the steps for doing such a complicated task.
1. Structure Re-Orgnization
Replace all of the md
files and markdown
files’s categories
:
$ cd /home/xxxxx/Code/purplepalmxxxx.github.io/src/content/post
$ find . | xargs -I % sed -i 's/categories\ =.*/categories\ =\ ["Technology"]/g' %
$ find . | xargs -I % sed -i 's/categories:.*/categories:\ ["Technology"]/g' %
Some of the old markdown files didn’t have categories, manually add them:
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-07-*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-08-*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-09-*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-10-*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-11-0*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-11-11*
$ sed -i '2s/$/categories:\ ["Technology"]/' 2013-11-12*
By-now all of the posts are Technology
related, manually change some posts
to LinuxTips
and Life
.
2. Upgrade hugo
Download the newest hugo version from official site and put it in binary
directory:
$ cd binaries
$ ls
hugo hugo_v031
$ ./hugo version
Hugo Static Site Generator v0.64.1/extended linux/amd64 BuildDate: unknown
Adjust some for generate properly(hyde-a theme adjustment):
$ rm -f
/home/xxxx/Code/purplepalmxxxx.github.io/src/themes/hyde-a/layouts/post/post.html
$ vim
/home/xxxx/Code/purplepalmxxxx.github.io/src/themes/hyde-a/layouts/index.html
{{ partial "head.html" . }}
<div class="content container">
<div class="posts">
+++ {{ $paginator := .Paginate (where .Site.RegularPages "Type" "in" site.Params.mainSections) }}
{{ range $paginator.Pages }}
Now commit all of the changes, the ci/cd for blogging will automatically use
the newest version of hugo for building-out the static website.
Feb 14, 2020
Technology0. AIM
For deploying Ovirt HyperConverged in air-gapped environment.
For some companies, their inner environment is air-gapped, e.g OA network. In
such air-gapped environment we could only use ISO and take some packages in
cd-roms for taking into their intra-network. How to deploy a ovirt drivened
private cloud in air-gapped room, I will take some experiment and try the
solution out.
1. Environment
In this chapter the environment will be available for ovirt deployment with glusterfs.
1.1 Hardware
I use my home machine for building the environment, the hardware is listed as:
CPU: Intel(R) Core(TM) i5-4460 CPU @ 3.20GHz
Memory: DDR3 1600 32G
Disk: 1T HDD.
1.2 OS/Networking/Software
My home machine runs ArchLinux, with nested virtualization.
Use qemu and virt-manager for setting the environment.
# qemu-system-x86_64 --version
QEMU emulator version 4.2.0
Copyright (c) 2003-2019 Fabrice Bellard and the QEMU Project developers
# virt-manager --version
2.2.1
I setup a isolated networking in virt-manager, cidr is 10.20.30.0/24, 3 vms
will use this isolated networking for emulating the air-gapped environment, its name is ovirt-isolated
:
data:image/s3,"s3://crabby-images/ed812/ed8126e3cbbfbf60b4f8e1c38a37ff32f0b530fd" alt="/images/2020_02_14_14_51_10_545x560.jpg"
1.3 VMs Preparation
I use 3 vms for setting up the environment, each of them have:
2 vcpus
10240 MB memory
vda: 100 GB, for installing the system.
vdb: 300 GB, for setting up the storage network.
NIC: 1x, attached to ovirt-isolated networking.
hostname - IP is listed as following:
instance1.com 10.20.30.31
instance2.com 10.20.30.32
instance3.com 10.20.30.33
engineinstance.com 10.20.30.34
For setting up the ip address, use nmtui
in terminal, take instance1.com for example:
data:image/s3,"s3://crabby-images/4820a/4820a0726f09bb03a15aa5c370a37f6225fd71ce" alt="/images/2020_02_14_15_20_56_601x304.jpg"
For setting up the hostname, also use nmtui
:
data:image/s3,"s3://crabby-images/4380b/4380bbd50e704e687c8502576296cc521b76e69a" alt="/images/2020_02_14_15_22_33_450x232.jpg"
Login to each machine and enable the password-less login, take instance1 for example:
# ssh-keygen
# vim /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
10.20.30.31 instance1.com
10.20.30.32 instance2.com
10.20.30.33 instance3.com
10.20.30.34 engineinstance.com
# ssh-copy-id root@instance1.com
# ssh-copy-id root@instance2.com
# ssh-copy-id root@instance3.com
Also add following items(engine vm’s hostname and ip address) into host machine(archLinux)‘s /etc/hosts
:
10.20.30.31 instance1.com
10.20.30.32 instance2.com
10.20.30.33 instance3.com
10.20.30.34 engineinstance.com
2. Deploy Glusterfs
Use firefox for visiting https://10.20.30.31:9090
:
data:image/s3,"s3://crabby-images/5dc60/5dc60d141b617f65688d7032c3dc1c725a9c675c" alt="/images/2020_02_14_15_39_07_796x287.jpg"
use root for login, enter the instance1.com
's cockpit web:
data:image/s3,"s3://crabby-images/87044/87044f4b18b9b7a96938274412630cfcaa3e2ce9" alt="/images/2020_02_14_15_39_38_728x474.jpg"
Click V
->Hosted Engine
, then click the start
button under Hyperconverged
:
data:image/s3,"s3://crabby-images/a2de0/a2de02aed95d1bcfd7759231a212bea30c97cb31" alt="/images/2020_02_14_15_42_07_1040x611.jpg"
Click Run Gluster Wizard
:
data:image/s3,"s3://crabby-images/348c9/348c9cc84b3570d777bafe12cf21b59525dd8d2f" alt="/images/2020_02_14_15_43_46_665x134.jpg"
Fill in 3 nodes’s hostname, click next
:
data:image/s3,"s3://crabby-images/7ea05/7ea0590a936611db73ac3b9f25a0242fc3a995b3" alt="/images/2020_02_14_15_45_01_890x403.jpg"
In Additional Hosts
, click Use same hostnames as in previous step
, thus Host2 and Hosts3 will be added automatically:
data:image/s3,"s3://crabby-images/ade40/ade40b0d142bf61b92b38da6625128e9f37750c2" alt="/images/2020_02_14_15_47_45_880x515.jpg"
In Packages
we keep the default empty items and click next for continue.
Keep the default volumn setting, and enable the Arbiter for data
and vmstore
:
data:image/s3,"s3://crabby-images/6ac97/6ac97f063035cde6ec0b7b45d17a0790b8181679" alt="/images/2020_02_14_15_57_02_843x459.jpg"
Here we adjust the LV device name to vdb
, and adjust the size as 80,80,80
, click next for continue:
The volume size for running engine vm should be at least 58GB(ovirt default minimum size, actually takes more than this number. )
data:image/s3,"s3://crabby-images/8c307/8c3074d89f780f970253988b1b8ecf55b3db1147" alt="/images/2020_02_14_16_00_34_809x611.jpg"
Review and click deploy:
data:image/s3,"s3://crabby-images/8129d/8129d3218fed00468fad578105bd5b16b1913c8f" alt="/images/2020_02_14_16_02_53_870x648.jpg"
The ansible tasks will run until you see this hint:
data:image/s3,"s3://crabby-images/c21df/c21df1e364c2de8062cf685bee79d70db08a5d44" alt="/images/2020_02_14_16_09_18_602x375.jpg"
Click Continue to hosted engine deployment
to continue.
3. Hosted Engine
Before continue, manually install the rpms in instance1.com
:
# yum install -y ./ovirt-engine-appliance-4.3-20200127.1.el7.x86_64.rpm
# rpm -qa | grep ovirt-engine-appliance
ovirt-engine-appliance-4.3-20200127.1.el7.x86_64
Fill the engine vm’s configuration infos:
data:image/s3,"s3://crabby-images/88018/88018d54039cab9a99ce44fdd96670d1bd569856" alt="/images/2020_02_14_16_23_51_518x881.jpg"
Fill in admin portal password(this password will be used in web login) and continue:
data:image/s3,"s3://crabby-images/400b4/400b492de3d05140e1fc974d0aea833cd08faa6a" alt="/images/2020_02_14_16_25_19_817x557.jpg"
Examine the configuration and click Prepare VM
:
data:image/s3,"s3://crabby-images/400b4/400b492de3d05140e1fc974d0aea833cd08faa6a" alt="/images/2020_02_14_16_25_19_817x557.jpg"
Wait for about half an hour to see deployment successful:
data:image/s3,"s3://crabby-images/3408d/3408d60fb489f8252555f5ed81dfdfdaa3f9bb79" alt="/images/2020_02_14_17_00_27_713x388.jpg"
Keep the default configuration:
engine vm’s storage configuration will use Gluster, path will be Gluster’s
engine volumn, and its parameter is:
backup-volfile-servers=instance2.com:instance3.com
for preventing the single-node issue for Gluster.
data:image/s3,"s3://crabby-images/ae16c/ae16c38cbe06d29f3b59d8b3a5eaf8f7fec279d0" alt="/images/2020_02_14_17_17_52_772x455.jpg"
Click Finish deployment
, and wait for a break:
data:image/s3,"s3://crabby-images/87cc3/87cc3dd4f0636165895e23ad707b8d53cecda4f3" alt="/images/2020_02_14_17_20_30_817x433.jpg"
Seeing this means deploy succeeded:
data:image/s3,"s3://crabby-images/02f24/02f243d82a6cd8499ce34041a950a66f0d750b99" alt="/images/2020_02_14_17_40_22_591x535.jpg"
Refresh the status:
data:image/s3,"s3://crabby-images/68533/68533bde45619b443cc9aa7ba93e5826b636abfb" alt="/images/2020_02_14_17_43_43_1058x513.jpg"
4. Portal
Visit engineinstance.com
in host machine(ArchLinux):
data:image/s3,"s3://crabby-images/91564/915649a51b2004dbfff5becc2497742adf3af606" alt="/images/2020_02_14_17_47_13_767x501.jpg"
Click Administration Portal
:
data:image/s3,"s3://crabby-images/db297/db2972caed77efa9c79734d16e6d03c20d2e5ec2" alt="/images/2020_02_14_17_48_30_499x308.jpg"
admin page is like following:
data:image/s3,"s3://crabby-images/8b712/8b712102e7576c316b15255b952947a495c44b25" alt="/images/2020_02_14_17_50_57_1221x561.jpg"
ssh into engine vm and check the disk partitions:
# ssh root@10.20.30.34
root@10.20.30.34's password:
Last login: Fri Feb 14 17:25:51 2020 from 192.168.1.1
[root@engineinstance ~]#df -h
Filesystem Size Used Avail Use% Mounted on
devtmpfs 1.9G 0 1.9G 0% /dev
tmpfs 1.9G 12K 1.9G 1% /dev/shm
tmpfs 1.9G 8.9M 1.9G 1% /run
tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup
/dev/mapper/ovirt-root 8.0G 2.3G 5.8G 29% /
/dev/mapper/ovirt-home 1014M 33M 982M 4% /home
/dev/mapper/ovirt-tmp 2.0G 33M 2.0G 2% /tmp
/dev/mapper/ovirt-var 20G 437M 20G 3% /var
/dev/vda1 1014M 157M 858M 16% /boot
/dev/mapper/ovirt-log 10G 45M 10G 1% /var/log
/dev/mapper/ovirt-audit 1014M 34M 981M 4% /var/log/audit
tmpfs 379M 0 379M 0% /run/user/0
5. Create The First VM
5.1 Add ISO storage Domain
Login in to instance1.com
, configure nfs share storage for holding ISO
images:
[root@instance1 ]# mkdir -p /isoimages
[root@instance1 ]# chown 36:36 -R /isoimages/
[root@instance1 ]# chmod 0755 -R /isoimages/
[root@instance1 ]# vi /etc/exports
[root@instance1 ]# cat /etc/exports
/isoimages *(rw,sync,no_subtree_check,all_squash,anonuid=36,anongid=36)
[root@instance1 ]# systemctl enable --now nfs.service
Created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.
In ovirt manager portal , click Storage
->Storage Domain
, click New Domain
:
data:image/s3,"s3://crabby-images/d4d90/d4d903fa5d58d2c5f066d0b4c2a4b84250170887" alt="/images/2020_02_14_19_29_49_1046x337.jpg"
Fill in name and path information:
data:image/s3,"s3://crabby-images/926b0/926b06412c8a56704d8b6178b39be6e81d2a549a" alt="/images/2020_02_14_19_42_32_1006x355.jpg"
Finished adding isoimages:
data:image/s3,"s3://crabby-images/79aff/79aff4ff820170ee379b2e468bc1ee06186046d9" alt="/images/2020_02_14_19_32_52_919x263.jpg"
5.2 Upload iso
Login to engien vm(engineinstance.com), download the iso from official site,
we take ubuntu16.04.6 for example:
[root@engineinstance ~]# ovirt-iso-uploader -i isoimages upload ./ubuntu-16.04.6-server-amd64.iso
Please provide the REST API password for the admin@internal oVirt Engine user (CTRL+D to abort):
Uploading, please wait...
INFO: Start uploading ./ubuntu-16.04.6-server-amd64.iso
Uploading: [########################################] 100%
INFO: ./ubuntu-16.04.6-server-amd64.iso uploaded successfully
5.3 Create VM
Compute-> Virtual Machines, click new
button:
Fill in informations:
data:image/s3,"s3://crabby-images/d957a/d957a4b1110c2fab95239c7b2bf9f4055abdb2e7" alt="/images/2020_02_14_19_50_24_673x641.jpg"
Click advanced options, select Boot Options
, then attach uploaded iso:
data:image/s3,"s3://crabby-images/c24a4/c24a4d622e1906a8d99beba1b00409e2c8d07dd1" alt="/images/2020_02_14_19_52_09_917x511.jpg"
Click Disks, then click new
:
data:image/s3,"s3://crabby-images/ba117/ba117d3a53f32057855f791af2c64e97ebc89063" alt="/images/2020_02_14_20_00_20_1178x316.jpg"
Fill in options:
data:image/s3,"s3://crabby-images/3226b/3226bbe6a0b47db50606883fc9c54dd8880fc10b" alt="/images/2020_02_14_20_01_54_731x394.jpg"
Click this new machine, and select run->run once
:
data:image/s3,"s3://crabby-images/43aff/43aff73bf0199bb7ec25f04e4604df299bfacb3d" alt="/images/2020_02_14_19_53_19_852x380.jpg"
Click OK for installation:
data:image/s3,"s3://crabby-images/4fb0b/4fb0bd08610cae2ab953811fe8d953d6e124991a" alt="/images/2020_02_14_19_54_06_599x528.jpg"
The installation image will be shown:
data:image/s3,"s3://crabby-images/6fdc4/6fdc4f4421a3a44545ef83ca0f672a12341b376e" alt="/images/2020_02_14_19_55_49_641x534.jpg"
Configure installation options and wait until installation finished.
Since we use nested virtualization, the installation step will take a very
long time(>1h) for installing the os. For speedup, considering use NVME ssd
for locating the vm’s qcow2 files. Or use 3 physical servers.
On vm portal we could see our newly created vm:
data:image/s3,"s3://crabby-images/5b664/5b664a6a30ab825f8ad74ace4c457e4a293dc8c7" alt="/images/2020_02_14_21_03_33_764x485.jpg"
Examine the vms on instance1.com:
[root@instance1 isoimages]# virsh -r list
Id Name State
----------------------------------------------------
2 HostedEngine running
4 ubuntu1604 running
6. Create vm using template
6.1 Create template
Create template via:
data:image/s3,"s3://crabby-images/7ad52/7ad522fe696cd26c3a56ccef0e4f4586fb44db96" alt="/images/2020_02_14_21_49_05_743x666.jpg"
Check the status of template:
data:image/s3,"s3://crabby-images/d5f50/d5f500cfcb95d792293f1df8f9398eb2cac30326" alt="/images/2020_02_14_21_50_02_733x224.jpg"
6.2 Create vm
Create new vm using template:
data:image/s3,"s3://crabby-images/df70f/df70ff44522a030bfe0fa9031cc19b1358edaf94" alt="/images/2020_02_14_21_57_36_912x668.jpg"
Start the machine and check result:
data:image/s3,"s3://crabby-images/233a9/233a97912e3dd6af84cc5d98ae29d88e0c92a8f2" alt="/images/2020_02_14_22_05_30_1148x360.jpg"
7. Add hosts
In engine vm, add following items:
Then we add hosts of instance2.com
and instance3.com
:
data:image/s3,"s3://crabby-images/42f22/42f220be82b94e77355d6dfd873276adbe6e44b9" alt="/images/2020_02_14_22_16_23_904x687.jpg"
Result:
data:image/s3,"s3://crabby-images/ff136/ff136c4960ff5e3bdc8a845b55897e102f9e29ac" alt="/images/2020_02_14_22_17_48_860x208.jpg"