Dockerfile:

FROM harbor.test.com/sonar/sonarqube:6.5
RUN rm -rf $SONARQUBE_HOME/lib/bundled-plugins/sonar-ldap-plugin-2.1.0.507.jar
RUN cd $SONARQUBE_HOME/lib/bundled-plugins/ && \
curl -sSOL https://sonarsource.bintray.com/Distribution/sonar-ldap-plugin/sonar-ldap-plugin-2.1.0.507.jar && \
sed -i '/exec java.*/a \
-Dsonar.security.realm=LDAP \
-Dsonar.security.savePassword=false \
-Dldap.url=ldap://mail.test.cn:389 \
-Dldap.bindDn=uid=zimbra,cn=admins,cn=zimbra \
-Dldap.bindPassword=pppwwwddd \
-Dldap.user.baseDn=ou=people,dc=test,dc=cn \
-Dldap.user.request=uid={0} \
-Dldap.user.emailAttribute=mail \\'


mysql-rc.yaml


apiVersion: v1
kind: ReplicationController
metadata:
name: sonar-mysql
spec:
replicas: 1
selector:
app: sonar-mysql
template:
metadata:
labels:
app: sonar-mysql
spec:
containers:
- name: sonar-mysql
image: mysql:5.7
ports:
- containerPort: 3306
env:
- name: MYSQL_ROOT_PASSWORD
value: "123456"
- name: MYSQL_DATABASE
value: sonardb
- name: MYSQL_USER
value: sonar
- name: MYSQL_PASSWORD
value: sonar
volumeMounts:
- mountPath: /var/lib/mysql
readOnly: false
name: sonar-mysql
volumes:
- name: sonar-mysql
nfs:
server: 192.168.1.131
path: "/data/nfs/sonar"


mysql-svc.yaml

apiVersion: v1
kind: Service
metadata:
name: sonar-mysql
spec:
ports:
- port: 3306



sonar-rc.yml



sonar-svc.yaml

apiVersion: v1
kind: Service
metadata:
name: sonar
spec:
type: NodePort
ports:
- port: 9000
targetPort: 9000


sonar-ingress.yaml



apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: sonar-ingress
spec:
rules:
- host: sonar.test.com
http:
paths:
- path: /
backend:
serviceName: sonar
servicePort: 9000