1. 程式人生 > >Kubernetes連接外部數據源

Kubernetes連接外部數據源

完全 amd64 sse 需要 con 映射 man 配置 註意

Kubernetes架構下比較核心的問題是數據如何persistance,雖然提供了Persistent volumn的方式,但是對於像數據庫之類的產品在kubernetes集群環境中運行和管理還是很有難度的,Kubernetes提供了endpoints這種模式讓外部的服務映射成內部的服務,這樣比較好的解決了集群對外的連接問題,

如果我們去連接外部的一個oracle數據庫,具體的步驟如下:

  • 建立endpoints和service.
[[email protected] jdbcservice]# cat jdbc-endpoint.yaml 
apiVersion: v1
kind: Endpoints
metadata:
  name: jdbc
subsets:
  
- addresses: - ip: 10.182.168.244 ports: - port: 1521 protocol: TCP

為了方便,我們固定了service的集群地址

[[email protected]master jdbcservice]# cat jdbcservice.yaml 
apiVersion: v1
kind: Service
metadata:
  name: jdbc
spec:
  clusterIP: 10.254.150.201
  ports:
  - port: 1521
    targetPort: 1521
protocol: TCP

需要註意的是,service和endpoints的名字要相同,另外如果delete了service.再重新建立的時候要再把endpoints建立一遍。

在這個service的表裏,我們看到jdbc服務綁在了201這個地址上。

[[email protected] jdbcservice]# kubectl get services
NAME            CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGE
helloworldsvc   10.254.43.122    <nodes>       7001
:30001/TCP 12m jdbc 10.254.150.201 <none> 1521/TCP 30m kubernetes 10.254.0.1 <none> 443/TCP 121d registry 10.254.174.54 <nodes> 5000:30002/TCP 20h

  • images的配置

然後對我們的weblogic images進行jdbc的配置。

技術分享

點擊Test Configuration,如果測試不過,weblogic不允許建立連接池成功.

技術分享

技術分享

在運行pod的節點上運行docker ps找到啟動image的容器id.

[[email protected]1 ~]# docker ps
CONTAINER ID        IMAGE                                                        COMMAND                  CREATED             STATUS              PORTS               NAMES
d2c1dc2a2cef        1213-helloworld:v1                                           "startWebLogic.sh"       7 minutes ago       Up 7 minutes                            k8s_weblogichelloworld.9efb3a79_helloworld-service-vfd10_default_6162d68a-9da9-11e7-b746-08002797edef_026d2cc4
85e04042041a        registry.access.redhat.com/rhel7/pod-infrastructure:latest   "/pod"                   7 minutes ago       Up 7 minutes                            k8s_POD.15c40ba1_helloworld-service-vfd10_default_6162d68a-9da9-11e7-b746-08002797edef_b59984a7
96acfd65eb3a        registry                                                     "/entrypoint.sh /etc/"   23 minutes ago      Up 23 minutes                           k8s_registry.71ab5625_registry-7nj8q_default_19ab0b7f-9cff-11e7-bf9d-08002797edef_fb5ae620
63652932256c        registry.access.redhat.com/rhel7/pod-infrastructure:latest   "/pod"                   23 minutes ago      Up 23 minutes                           k8s_POD.100f0b9e_registry-7nj8q_default_19ab0b7f-9cff-11e7-bf9d-08002797edef_98dd7f3f
1ed61c53625f        gcr.io/google_containers/etcd-amd64:2.2.1                    "/usr/local/bin/etcd "   47 minutes ago      Up 47 minutes                           k8s_etcd.bb974d90_kube-dns-v11-x0vr3_kube-system_5dd26461-3ef1-11e7-acf2-08002797edef_7316989c
fb8545a4aba4        gcr.io/google_containers/exechealthz:1.0                     "/exechealthz ‘-cmd=n"   47 minutes ago      Up 47 minutes                           k8s_healthz.525e4aad_kube-dns-v11-x0vr3_kube-system_5dd26461-3ef1-11e7-acf2-08002797edef_cec4d740
aa6c4caf3fa7        gcr.io/google_containers/skydns:2015-10-13-8c72f8c           "/skydns -machines=ht"   47 minutes ago      Up 47 minutes                           k8s_skydns.96837166_kube-dns-v11-x0vr3_kube-system_5dd26461-3ef1-11e7-acf2-08002797edef_5da89b81
5930dae5b843        registry.access.redhat.com/rhel7/pod-infrastructure:latest   "/pod"                   47 minutes ago      Up 47 minutes                           k8s_POD.4efc54ff_kube-dns-v11-x0vr3_kube-system_5dd26461-3ef1-11e7-acf2-08002797edef_3e3af088

生成新的images

[[email protected]1 ~]# docker commit -m "jdbc" -a "ericnie" d2c1dc2a2cef 1213-helloworld-jdbc:v1
sha256:953e124483d2bcc03b3f46c8e6d935e3746634d78942cc477e31888c8d569171

  • 驗證

修改weblogic replication control指向1213-helloworld-jdbc:v1 images,啟動後看到連接建立.

weblogic端

技術分享

數據庫端

數據庫端原來的jdbc鏈接

技術分享

Pod完全啟動後的連接

技術分享

Kubernetes連接外部數據源