mirror of
https://github.com/google/nomulus.git
synced 2025-04-30 12:07:51 +02:00
Use bazel rules to build docker image and push to GCR
Using bazel to build and push image result in reproducible builds. ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=187252645
This commit is contained in:
parent
9e3fb8b93c
commit
753a269357
6 changed files with 53 additions and 88 deletions
22
WORKSPACE
22
WORKSPACE
|
@ -24,3 +24,25 @@ closure_repositories(
|
||||||
load("//java/google/registry:repositories.bzl", "domain_registry_repositories")
|
load("//java/google/registry:repositories.bzl", "domain_registry_repositories")
|
||||||
|
|
||||||
domain_registry_repositories()
|
domain_registry_repositories()
|
||||||
|
|
||||||
|
# Setup docker bazel rules
|
||||||
|
git_repository(
|
||||||
|
name = "io_bazel_rules_docker",
|
||||||
|
remote = "https://github.com/bazelbuild/rules_docker.git",
|
||||||
|
tag = "v0.4.0",
|
||||||
|
)
|
||||||
|
|
||||||
|
load(
|
||||||
|
"@io_bazel_rules_docker//container:container.bzl",
|
||||||
|
"container_pull",
|
||||||
|
container_repositories = "repositories",
|
||||||
|
)
|
||||||
|
|
||||||
|
container_repositories()
|
||||||
|
|
||||||
|
container_pull(
|
||||||
|
name = "java_base",
|
||||||
|
registry = "gcr.io",
|
||||||
|
repository = "distroless/java",
|
||||||
|
digest = "sha256:780ee786a774a25a4485f491b3e0a21f7faed01864640af7cebec63c46a0845a",
|
||||||
|
)
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
# This package contains the code for the binary that proxies TCP traffic from
|
# This package contains the code for the binary that proxies TCP traffic from
|
||||||
# the GCE/GKE to AppEngine.
|
# the GCE/GKE to AppEngine.
|
||||||
|
|
||||||
|
load("@io_bazel_rules_docker//container:container.bzl", "container_image", "container_push")
|
||||||
|
|
||||||
package(
|
package(
|
||||||
default_visibility = ["//java/google/registry:registry_project"],
|
default_visibility = ["//java/google/registry:registry_project"],
|
||||||
)
|
)
|
||||||
|
@ -48,3 +50,28 @@ java_binary(
|
||||||
"@io_netty_tcnative",
|
"@io_netty_tcnative",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
container_image(
|
||||||
|
name = "proxy_image",
|
||||||
|
base = "@java_base//image",
|
||||||
|
entrypoint = [
|
||||||
|
"java",
|
||||||
|
"-jar",
|
||||||
|
"proxy_server_deploy.jar",
|
||||||
|
],
|
||||||
|
files = [":proxy_server_deploy.jar"],
|
||||||
|
ports = [
|
||||||
|
"30000",
|
||||||
|
"30001",
|
||||||
|
"30002",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
container_push(
|
||||||
|
name = "proxy_push",
|
||||||
|
format = "Docker",
|
||||||
|
image = ":proxy_image",
|
||||||
|
registry = "gcr.io",
|
||||||
|
repository = "GCP_PROJECT/IMAGE_NAME",
|
||||||
|
tag = "bazel",
|
||||||
|
)
|
||||||
|
|
|
@ -52,7 +52,7 @@ kms:
|
||||||
cryptoKey: your-kms-cryptoKey
|
cryptoKey: your-kms-cryptoKey
|
||||||
|
|
||||||
epp:
|
epp:
|
||||||
port: 700
|
port: 30002
|
||||||
relayHost: registry-project-id.appspot.com
|
relayHost: registry-project-id.appspot.com
|
||||||
relayPath: /_dr/epp
|
relayPath: /_dr/epp
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ epp:
|
||||||
customQuota: []
|
customQuota: []
|
||||||
|
|
||||||
whois:
|
whois:
|
||||||
port: 43
|
port: 30001
|
||||||
relayHost: registry-project-id.appspot.com
|
relayHost: registry-project-id.appspot.com
|
||||||
relayPath: /_dr/whois
|
relayPath: /_dr/whois
|
||||||
|
|
||||||
|
|
|
@ -1,24 +0,0 @@
|
||||||
# Copyright 2018 The Nomulus Authors. All Rights Reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
FROM openjdk:8
|
|
||||||
|
|
||||||
WORKDIR /proxy
|
|
||||||
|
|
||||||
COPY ./proxy_server_deploy.jar /proxy/
|
|
||||||
|
|
||||||
ENTRYPOINT ["java", "-jar", "proxy_server_deploy.jar"]
|
|
||||||
|
|
||||||
# Ports used for health checking, WHOIS and EPP, respecitvely.
|
|
||||||
EXPOSE 30000 30001 30002
|
|
|
@ -1,61 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
# Copyright 2018 The Nomulus Authors. All Rights Reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# This script builds the proxy jar file with all of its dependencies included,
|
|
||||||
# then puts it in an image with a name compatible with GCR. If a "push"
|
|
||||||
# argument is given, it also uploads the image to GCR.
|
|
||||||
|
|
||||||
function cleanup() {
|
|
||||||
rm ${WORKDIR}/${TARGET} -f
|
|
||||||
}
|
|
||||||
|
|
||||||
trap cleanup EXIT
|
|
||||||
|
|
||||||
PROJECT=`gcloud config list 2>&1 | grep project | awk -F'= ' '{print $2}'`;
|
|
||||||
|
|
||||||
echo "PROJECT: ${PROJECT}"
|
|
||||||
|
|
||||||
PACKAGE_PREFIX=""
|
|
||||||
|
|
||||||
PACKAGE=${PACKAGE_PREFIX}"java/google/registry/proxy"
|
|
||||||
|
|
||||||
TARGET=proxy_server_deploy.jar
|
|
||||||
|
|
||||||
BUILD_TOOL=bazel
|
|
||||||
|
|
||||||
WORKSPACE=`$BUILD_TOOL info workspace`
|
|
||||||
|
|
||||||
WORKDIR=${WORKSPACE}/${PACKAGE}/kubernetes
|
|
||||||
|
|
||||||
BINDIR=${WORKSPACE}/${BUILD_TOOL}-bin/${PACKAGE}
|
|
||||||
|
|
||||||
$BUILD_TOOL build "//"${PACKAGE}:${TARGET}
|
|
||||||
|
|
||||||
cp ${BINDIR}/${TARGET} ${WORKDIR}/
|
|
||||||
|
|
||||||
docker build -t gcr.io/${PROJECT}/proxy:latest $WORKDIR
|
|
||||||
|
|
||||||
# Publish the image to GCR if "push" argument is given.
|
|
||||||
if [ -z $1 ]
|
|
||||||
then
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ $1 = "push" ]
|
|
||||||
then
|
|
||||||
gcloud docker -- push gcr.io/${PROJECT}/proxy:latest
|
|
||||||
else
|
|
||||||
echo "usage: $0 [push]"
|
|
||||||
fi
|
|
|
@ -20,7 +20,7 @@ spec:
|
||||||
secretName: proxy-account
|
secretName: proxy-account
|
||||||
containers:
|
containers:
|
||||||
- name: proxy
|
- name: proxy
|
||||||
image: INSERT_YOUR_IMAGE_NAME_HERE
|
image: gcr.io/GCP_PROJECT/IMAGE_NAME:bazel
|
||||||
ports:
|
ports:
|
||||||
- containerPort: 30000
|
- containerPort: 30000
|
||||||
name: health-check
|
name: health-check
|
||||||
|
@ -41,6 +41,7 @@ spec:
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- name: service-account
|
- name: service-account
|
||||||
mountPath: /var/secrets/google
|
mountPath: /var/secrets/google
|
||||||
|
imagePullPolicy: Always
|
||||||
args: ["--log"]
|
args: ["--log"]
|
||||||
env:
|
env:
|
||||||
- name: GOOGLE_APPLICATION_CREDENTIALS
|
- name: GOOGLE_APPLICATION_CREDENTIALS
|
||||||
|
|
Loading…
Add table
Reference in a new issue