Ubuntu1604ISOCustomize

Steps

ArchLinux Preparation:

$ yaourt mkpasswd
# mkdir aiiso
# cd aiiso
# mv ../ubuntu-16.04.5-server-amd64.iso .
# mkdir newISO
# mkdir iso
# mount -o loop ./ubuntu-16.04.5-server-amd64.iso ./iso
# cp -r ./iso/* ./newISO
# cp -r ./iso/.disk ./newISO
# umount ./iso
# cp xxx.seed ./newISO/preseed
###### Make some customization
#  md5sum ./newISO/preseed/xxx.seed
ed9a5e91f66451080d27d3d85032801d  xxx.seed
# vim preseed/xxx.seed
# vim isolinux/txt.cfg
# mkisofs -D -r -V "NETSON_UBUNTU" -cache-inodes -J -l -b isolinux/isolinux.bin -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table -o ../ai_ubuntu.iso .  > /dev/null 2>&1
# isohybrid ../ai_ubuntu.iso

TipsOnLightdm

Steps

Install lightdm via:

$ sudo pacman -S lightdm

but this will cause gui startup failed.

/images/2018_11_24_21_09_12_541x252.jpg

Changes to lxdm solves the problem:

# pacman -S lxde
# systemctl enable lxdm.service
# vim /etc/lxdm/lxdm.conf
####autologin=dgod
# vim /root/.dmrc
[Desktop]
Session=xfce

Install:

# pacman -S xorg lightdm-gtk-greeter xterm xorg-xinit awesome
# vim /etc/lightdm.conf
greeter-session=lightdm-gtk-greeter

Add configuration for lightdm-gtk-greeter

Desktop Manager session:

 cat ~/.dmrc 
[Desktop]
Session=awesome

Install:

$ groupadd -r autologin
$ gpasswd -a root autologin
$ pacman -S xfce4-goodies
$ pacman -S awesome

TipsOnHarbor

Harbor Configuration

Create user via:

/images/2018_11_23_11_06_47_554x475.jpg

Create project:

/images/2018_11_23_11_07_08_813x347.jpg

Add member:

Before:

/images/2018_11_23_11_07_21_660x305.jpg

Added:
/images/2018_11_23_11_07_36_618x403.jpg

After:

/images/2018_11_23_11_07_55_660x319.jpg

Now docker-compose down the environment, backup the folder:

Installation System

Configure the ip address:

/images/2018_11_23_15_30_44_643x347.jpg

All nodes should be pointing to the dns address:

/images/2018_11_23_15_33_04_681x477.jpg

TipsOnRongISO

AIM

For building the kubespray offline all-in-one deploying iso.

Steps

  1. Download 7.5.1804 ISO.
  2. Create a new virtual machine, kvm based, minimal installation, for getting the minimal vm files.
  3. Install redsocks, compile it, then shutdown the minimal vm.
  4. Create a qcow2 file based on minimal vm, start the vm, then change the IP/Netmask/DNS.
  5. Start redsocks. Test the unlimited networking.
  6. Clone the kubespray repository, deploy the kubespray in all in one node.
  7. Fetch the rpms from the kubespray all-in-one node.
  8. Create a isolated networking and setup the offline environment.
  9. Modify the kubespray source code for offline deployment.
  10. Portus offline registry repo building.
  11. Static website for holding static files(rpms/hypekube).
  12. docker use intranet registry/ rpm use static website.

TobeDone

Steps for building deployment system.

1. 
docker-compose
portus (docker-compose) composition files. 
portus images. 

2. 
inventory file(top layer)
kubespray files will be uploaded to deployment node. 

3. 
dns server setup
manually add dns server in all of the nodes. 

4. 
If initial environment is ok, then deploy environment will also be ok.  

MakingOfflineKubeSprayDeploymentISO

1. Portus纯净版制作

vagrant启动ubuntu14.04, 安装docker/docker-compose, 注意事项:

$ sudo apt-get purge lxc-docker-1.9.0
$ sudo apt-get install \
    linux-image-extra-$(uname -r) \
    linux-image-extra-virtual
$ sudo apt-get update
$ sudo apt-get install -y \
    apt-transport-https \
        ca-certificates \
            curl \
                software-properties-common

$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
$ sudo apt-key fingerprint 0EBFCD88
$ sudo add-apt-repository \
   "deb [arch=amd64] https://download.docker.com/linux/ubuntu \
      $(lsb_release -cs) \
         stable"
$ sudo apt-get update
$ sudo apt-get install -y docker-ce
$ sudo apt-get install -y libyaml-dev libpython-dev
$ sudo pip uninstall docker-py
$ sudo pip uninstall docker-compose
$ sudo pip install --upgrade --force-reinstall  docker-compose

而后用我们预先定义好的compose目录(compose.tar.gz解压到/usr/local/compose目录下), 更改IP地址与域名的映射,extra_hosts:条目, 全翻墙条件下,一条命令启动:

# cd /usr/local/compose
# docker-compose up

因为我们预先已经定义好了域名与IP的配置,我们这里定义的内网IP为192.168.33.18, 于是在有浏览器的192.168.33.1机器上,配置/etc/hosts下的DNS条目:

# vim /etc/hosts
portus.xxxx.com	192.168.33.18

打开浏览器访问https://portus.xxxx.com,第一次登录需要配置admin的邮箱及密码:

/images/2018_11_15_11_34_49_515x420.jpg

配置远端registry仓库:

/images/2018_11_15_11_37_44_379x197.jpg

创建一个kubespray团队:

/images/2018_11_15_11_39_26_913x404.jpg

User条目中,创建一个kubespray的用户:

/images/2018_11_15_11_41_24_477x321.jpg

kubespray团队下添加kubespray用户:

/images/2018_11_15_11_42_38_492x306.jpg

创建一个命名空间用于存放kubespray部署镜像:

/images/2018_11_15_11_43_40_907x344.jpg

此刻Dashboard上可以看到我们刚才进行的操作。而在外部则可以通过docker login来登录到此仓库。

现在关闭docker-compose启动的容器,备份好关键目录:

# cd /usr/local/compose/
# docker-compose down
Stopping compose_nginx_1_3541e93c08a9      ... done
Stopping compose_background_1_42f1644b8fea ... done
Stopping compose_registry_1_e6eb6ee23d0a   ... done
Stopping compose_portus_1_90c30953f8b0     ... done
Stopping compose_db_1_45dc41479cee         ... done
Removing compose_nginx_1_3541e93c08a9      ... done
Removing compose_background_1_42f1644b8fea ... done
Removing compose_registry_1_e6eb6ee23d0a   ... done
Removing compose_portus_1_90c30953f8b0     ... done
Removing compose_db_1_45dc41479cee         ... done
Removing network compose_default
# cd /var/lib
# tar cJvf portus.tar.xz portus/
# ls -l -h portus.tar.xz 
-rw-r--r-- 1 root root 687K Nov 15 03:49 portus.tar.xz

由上面可见,portus下现在没有任何上传的镜像及数据文件,整个目录压缩后仅1M不到的空间。

我们也需要portus运行所需要的所有镜像,使用下列命令打包成一个压缩后的镜像, 以便我们在编译ISO时使用:

# docker save $(docker images -q) -o portus_combine.tar
# ls -l -h portus_combine.tar 
-rw------- 1 root root 584M Nov 15 03:58 portus_combine.tar

由章节1我们得到用于制作Portus纯净仓库的文件, portus_combine.tarportus.tar.xz,用于后续的部署ISO编译使用。

1.1 vagrant box引出

将上述的文件放到/home/vagrant目录, 并更改root的密码为txxxxxxr, 打包该虚拟机,以后我们将直接由vagrant box来批量执行.

# pwd
/home/vagrant
# ls
compose.tar.gz  portus_combine.tar  portus.tar.xz

打包该vagrant实例为box:

# vagrant status
Current machine states:

default                   poweroff (virtualbox)

The VM is powered off. To restart the VM, simply run `vagrant up`
# vagrant package --output portusBase.box
# ls -l -h portusBase.box
-rw-r--r-- 1 dash root 1.7G Nov 15 12:27 portusBase.box

2. kubespray容器镜像

VPS改写kubespray脚本,取回需要的容器镜像.

以下是本地镜像:
取回后的所有容器镜像,打包到/vagrant目录下:

# docker save $(docker images -q) -o kubespray_images.tar
# ls -l -h kubespray_images.tar 
-rw------- 1 root root 4.9G Nov 14 20:37 kubespray_images.tar

3. Portus部署仓库制作

由纯净版的box启动虚拟机,加载上一章制作出来容器镜像。