解决了好几个软件的构建问题,在解决部署问题,bluemix部署
https://www.puteulanus.com/archives/838#comment-961
新版 Bluemix 一键搭建 SS 脚本
https://blog.feixueacg.com/bluemix-stop-docker/
IBM CLOUD Kubernetes 集群简易教程
磕了几天kubernetes教程,还是云里雾里。
先记录有用的东西吧
#!/bin/bash # 定义参数检查 paras=$@ function checkPara(){ local p=$ for i in $paras; do if [[ $i == $p ]]; then return; fi; done false } # 设定区域 REGION=ng checkPara 'au' && REGION=au-syd # Sydney, Australia checkPara 'uk' && REGION=eu-gb # London, England checkPara 'de' && REGION=eu-de # Frankfurt, Germany # 检查 BBR 参数 BBR=false checkPara 'bbr' && BBR=true # 安装 unrar #wget https://coding.net/u/tprss/p/bluemix-source/git/raw/master/v2/unrar #chmod +x ./unrar #sudo mv ./unrar /usr/bin/ # 安装 kubectl #wget -O kubectl.rar 'http://detect-10000037.image.myqcloud.com/5c964783-429d-4e31-a286-6580c97d4ac1' #unrar x kubectl.rar curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl chmod +x ./kubectl sudo mv ./kubectl /usr/local/bin/kubectl # 安装 Bluemix CLI 及插件 # #unrar x Bluemix_CLI.rar #cd Bluemix_CLI #chmod +x install_bluemix_cli #sudo ./install_bluemix_cli #bluemix config --usage-stats-collect false #wget -O container-service-linux-amd64.rar 'http://detect-10000037.image.myqcloud.com/1eb05dc4-d8ba-4347-b932-30558134d9ee' #unrar x container-service-linux-amd64.rar #bx plugin install ./container-service-linux-amd64 wget -O Bluemix_CLI_amd64.tar.gz 'https://plugins.ng.bluemix.net/download/bluemix-cli/0.6.5/linux64' tar -zxf Bluemix_CLI_amd64.tar.gz cd Bluemix_CLI sudo ./install_bluemix_cli bluemix config --usage-stats-collect false bx plugin install container-service -r Bluemix # 初始化 #echo -e -n "\n请输入用户名:" #read USERNAME #echo -n '请输入密码:' #read -s PASSWD #echo -e '\n' #(; echo no) | bx login -a https://api.${REGION}.bluemix.net -u $USERNAME -p $PASSWD bx login -a https://api.${REGION}.bluemix.net (; ) | bx target --cf bx cs init $(bx cs cluster-config $(bx cs clusters | grep 'normal' | awk '{print $1}') | grep 'export') PPW=$(openssl rand -base64 | md5sum | head -c12) SPW=$(openssl rand -base64 | md5sum | head -c12) AKN=del_$(openssl rand -base64 | md5sum | head -c5) AK=$(bx iam api-key-create $AKN | | awk '{print $3}' | base64) # 尝试清除以前的构建环境 kubectl delete pod build >/dev/null kubectl delete deploy kube ss bbr >/dev/null kubectl delete svc kube ss ss-tcp ss-udp >/dev/null kubectl delete rs -l run=kube | grep 'deleted' --color=never kubectl delete rs -l run=ss | grep 'deleted' --color=never kubectl delete rs -l run=bbr | grep 'deleted' --color=never # 等待 build 容器停止 >& | grep -q "NotFound" do done # 创建构建环境 cat << _EOF_ > build.yaml apiVersion: v1 kind: Pod metadata: name: build spec: containers: - name: alpine image: docker:dind command: ["sleep"] args: ["] securityContext: privileged: true restartPolicy: Never _EOF_ kubectl create -f build.yaml >/dev/" do done IP=$(kubectl exec -it build -- wget -qO- whatismyip.akamai.com) PEM=$(basename $(ls ~/.bluemix/plugins/container-service/clusters/*/*.pem)) kubectl cp ~/.bluemix/plugins/container-service/clusters/*/*.yml build:/root/config kubectl cp ~/.bluemix/plugins/container-service/clusters/*/*.pem build:/root/"$PEM" (echo 'apk add --update curl ca-certificates openssl'; \ echo wget -O build.sh 'https://gist.githubusercontent.com/anonymous/dcc43cd069ad77453768f8505f73c836/raw/e930391795ea1c7af36306b098285bb12ebc89c4/build.sh'; \ echo sh build.sh "$AKN" "$AK" "$PPW" "$SPW" "$REGION" "$IP" "$BBR" "$PEM") | kubectl exec -it build sh # 输出信息 #PP=$(kubectl get svc kube -o=custom-columns=Port:.spec.ports\[\*\].nodePort | tail -n1) #SP=$(kubectl get svc ss -o=custom-columns=Port:.spec.ports\[\*\].nodePort | tail -n1) SP=443 #IP=$(kubectl get node -o=custom-columns=Port:.metadata.name | tail -n1) wget https://coding.net/u/tprss/p/bluemix-source/git/raw/master/v2/cowsay chmod +x cowsay cat << _EOF_ > default.cow \$the_cow = <<"EOC"; \$thoughts ^__^ \$thoughts (\$eyes)\\\\_______ (__)\\ )\\\\/\\\\ \$tongue ||----w | || || EOC _EOF_ clear echo ./cowsay -f ./default.cow 惊不惊喜,意不意外 echo echo ' 管理面板地址: ' http://$IP/$PPW/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy/ echo echo ' SS:' echo ' IP: '$IP echo ' Port: '$SP echo ' Password: '$SPW echo ' Method: aes-256-cfb' ADDR='ss://'$(echo -n "aes-256-cfb:$SPW@$IP:$SP" | base64) echo echo ' 快速添加: '$ADDR echo ' 二维码: http://qr.liantu.com/api.php?text='$ADDR echo
#!/bin/sh # 安装 docker #yum install -y yum-utils device-mapper-persistent-data lvm2 wget openssl #yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo #yum install docker-ce -y dockerd >/dev/>& & # 安装 kubectl curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl chmod +x ./kubectl mv ./kubectl /usr/local/bin/kubectl # 安装 Bluemix CLI 及插件 wget -O Bluemix_CLI_amd64.tar.gz 'https://plugins.ng.bluemix.net/download/bluemix-cli/0.6.5/linux64' tar -zxf Bluemix_CLI_amd64.tar.gz cd Bluemix_CLI sh ./install_bluemix_cli bluemix config --usage-stats-collect false #bx plugin install container-service -r Bluemix # 初始化 AKN=$ AK=$( | base64 -d) PPW=$ SPW=$ REGION=$ IP=$ BBR=$ PEM=$ export BLUEMIX_API_KEY=$AK (; echo no) | bx login -a https://api.${REGION}.bluemix.net (; ) | bx target --cf #bx cs init #$(bx cs cluster-config $(bx cs clusters | grep 'normal' | awk '{print $1}') | grep 'export') bx iam api-key-delete $AKN # 初始化镜像库 bx plugin install container-registry -r Bluemix bx cr login for name in $(bx cr namespace-list | grep del_); do (echo y) | bx cr namespace-rm $name; done NS=del_$(openssl rand -base64 | md5sum | head -c16) bx cr namespace-add $NS # 构建面板容器 #cp /root/.bluemix/plugins/container-service/clusters/*/*.yml ./config #cp /root/.bluemix/plugins/container-service/clusters/*/*.pem ./ #PEM=$(basename $(ls /root/.bluemix/plugins/container-service/clusters/*/*.pem)) cd /root/ wget -O caddy.tar.gz https://caddyserver.com/download/linux/amd64 tar -zxf caddy.tar.gz chmod +x ./caddy cp /usr/local/bin/kubectl ./ cat << _EOF_ > Caddyfile 0.0.0.0:80 gzip proxy /$PPW/ 127.0.0.1:8001 _EOF_ cat << _EOF_ > run.sh kubectl proxy --accept-hosts '.*' --api-prefix=/$PPW/ & caddy -conf /etc/caddy/Caddyfile _EOF_ cat << _EOF_ > Dockerfile FROM alpine:latest RUN apk add --update ca-certificates ADD kubectl /usr/local/bin/ RUN mkdir /root/.kube ADD config /root/.kube/config ADD $PEM /root/.kube/ ADD caddy /usr/local/bin/ RUN mkdir /etc/caddy ADD Caddyfile /etc/caddy/ ADD run.sh /root/ CMD sh /root/run.sh _EOF_ docker build -t registry.${REGION}.bluemix.net/$NS/kube . while ! bx cr image-list | grep -q "registry.${REGION}.bluemix.net/$NS/kube" do docker push registry.${REGION}.bluemix.net/$NS/kube done # 创建面板运行环境 kubectl run kube --image=registry.${REGION}.bluemix.net/$NS/kube --port=80 kubectl expose deployment kube --type=LoadBalancer --name=kube --external-ip $IP # 构建 SS 容器 cat << _EOF_ >Dockerfile FROM easypi/shadowsocks-libev ENV SERVER_PORT 443 ENV METHOD aes-256-cfb ENV PASSWORD $SPW _EOF_ docker build -t registry.${REGION}.bluemix.net/$NS/ss . while ! bx cr image-list | grep -q "registry.${REGION}.bluemix.net/$NS/ss" do docker push registry.${REGION}.bluemix.net/$NS/ss done # 创建 BBR 构建文件 cat << _EOF_ > bbr.yaml apiVersion: extensions/v1beta1 kind: Deployment metadata: labels: app: bbr name: bbr spec: replicas: 1 selector: matchLabels: app: bbr template: metadata: labels: app: bbr name: bbr spec: containers: - env: - name: TARGET_HOST value: SS_IP - name: TARGET_PORT value: "443" - name: BIND_PORT value: "443" image: wuqz/lkl:latest name: bbr securityContext: privileged: true restartPolicy: Always _EOF_ # 创建 SS 运行环境 kubectl run ss --image=registry.${REGION}.bluemix.net/$NS/ss --port=443 if $BBR; then kubectl expose deployment ss --name=ss sed -i "s/SS_IP/$(kubectl get svc ss -o=custom-columns=IP:.spec.clusterIP | tail -n1)/g" bbr.yaml kubectl create -f bbr.yaml kubectl expose deployment bbr --type=LoadBalancer --port=443 --name=ss-tcp --external-ip $IP else kubectl expose deployment ss --type=LoadBalancer --name=ss-tcp --external-ip $IP fi kubectl expose deployment ss --type=LoadBalancer --name=ss-udp --external-ip $IP --protocol="UDP" # 删除构建环境 kubectl delete pod build
这两个脚本是一键搭建 SS 脚本中用到的脚本。
意思还不是很理解。
大概是第一个脚本,安装了一个alpine。
第二个脚本又构建一个SS服务器。
不懂,继续研究。
怕脚本下载不到,先存一下。
解决了好几个软件的构建问题,在解决部署问题,bluemix部署的更多相关文章
- Adobe Illustrator CS6 界面文字按钮太小,高分屏win10PS/AI等软件界面字太小解决方法
Adobe Illustrator CS6 界面文字按钮太小,高分屏win10PS/AI等软件界面字太小解决方法 Adobe App Scaling on High DPI Displays (FIX ...
- 解决Genymotion不能安装软件的问题
解决Genymotion不能安装软件的问题 官方取消了with google apps字样的rom,导致安装app不兼容的解决 有些童鞋在兴奋的打开Genymotion模拟器后可能会发现无法安装下载下 ...
- 解决Adobe cs6系列软件在Windows10操作系统中无法正常运行问题
大家好,我是安德风,很高兴今天能给大家一起解决Adobe cs6系列软件在Windows10操作系统中无法正常运行的问题.今天我以Adobe Photoshop cs6在Windows10环境安装运行 ...
- 目录已存在导致Jenkins项目构建失败的解决方法
Jenkins中的项目在下载源代码时,如果Working Directory中存在未加入版本控制的文件或者目录已经存在于SVN库中,会导致更新失败,整个构建终止,解决方法是将SVN的检出策略由&quo ...
- CentOS6安装各种大数据软件 第十章:Spark集群安装和部署
相关文章链接 CentOS6安装各种大数据软件 第一章:各个软件版本介绍 CentOS6安装各种大数据软件 第二章:Linux各个软件启动命令 CentOS6安装各种大数据软件 第三章:Linux基础 ...
- Atitit.dwr3 不能显示错误具体信息的解决方式,控件显示错误具体信息的解决方式 java .net php
Atitit.dwr3 不能显示错误具体信息的解决方式,控件显示错误具体信息的解决方式 java .net php 1. Keyword/subtitle 1 2. 使用dwr3的异常convert处 ...
- CDH构建大数据平台-Kerberos高可用部署【完结篇】
CDH构建大数据平台-Kerberos高可用部署[完结篇] 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.安装Kerberos相关的软件包并同步配置文件 1>.实验环境 ...
- centos7.5 解决缺少libstdc++.so.6库的原因及解决办法
centos7. 解决缺少libstdc++.so.6库的原因及解决办法 执行node -v报错如下: [root@bogon ~]# node -v node: error : cannot ope ...
- 软件测试之构建测试---BVT
1. 构建的基本流程: a. 开发人员在他们的个人计算机上编写源代码文件 b. 他们将编写好的文件存放在一个统一集中的地方,构建组将所有的源代码编译成可以在计算机上运行的二进制文件,且用安装工具把各种 ...
随机推荐
- 使用Qss设置QT程序界面的样式和皮肤
1 使用Qss设置QT程序界面的样式和皮肤 1.1 Qss的功能 Qt程序界面中控件的背景图片.大小.字体颜色.字体类型.按钮状态变化等属性可以通过Qss文件来设置,美化UI界面.实 ...
- C# 递归缩小图片
需求:图片太大,上传到服务器会非常占用服务器空间,而系统又不要求高清图片,于是就通过递归的方式让图片每次减少10%的大小,当图片大小小于100k的时候就保存在本地,核心代码如下: class Prog ...
- POP3、SMTP和IMAP介绍和设置
什么是POP3.SMTP和IMAP? 参照:http://help.163.com/09/1223/14/5R7P6CJ600753VB8.html 用于 Outlook 的 POP 和 IMAP 电 ...
- 终于把joomla 的 protostar 模版的菜单,从垂直改到水平了
protostar-applying-menu-class-suffixes-horizontal-vs-vertical-menus.html joomla 3.7.5 附带的这个template ...
- linux: 安装jdk(java)
作为Java开发人员,在Linux下安装一些开发工具是必备技能,本文以安装jdk为例,详细记录了每一步的操作命令,以供参考. 0.下载jdk8 登录网址:http://www.oracle.com/t ...
- java开学第一周测试代码
Account.java /* 信1705-3 20173612 陈阳阳 */package ATM; public class Account { private String accountID ...
- Leetcode笔记(整理中.......)
1.树的层序遍历 使用两个List 数组 或者 两个queue队列,交替进行,将遍历到的一层放在第一个里面,之后再将遍历到的第二层放在第二个里面. 2.将一个无符号整数的二进制表示形式逆向输出 需要将 ...
- Educational Codeforces Round 2 E - Lomsat gelral
题意:每个节点有个值,求每个节点子树众数和 题解:可线段树合并,维护每个数出现次数和最大出现次数,以及最大出现次数的数的和 //#pragma GCC optimize(2) //#pragma GC ...
- Leetcode 129
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode ...
- WDA基础十二:FREE PROGRAM SH (WDA TREE)
一个需要用TREE展示搜索帮助的需求: 1.创建WDA程序:ZCATEGORY 2.Component Controller中添加节点: (说明,此节点仅在搜索帮助程序中使用,可以不用interfac ...