-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use jetstack public to build and fix Application wrangling #35
Conversation
I have cut a second release, My plan is to click "Submit for review" tonight (probably late), and have Google review Last note: I am still very unhappy with Here is a view of the Application UI after installing the application: step by step processFirst I built % gcloud builds submit --project jetstack-public --timeout 1800s --config cloudbuild.yaml \
--substitutions _CLUSTER_NAME=smoke-test,_CLUSTER_LOCATION=europe-west2-b,_APP_MINOR_VERSION=1.1,_APP_VERSION=1.1.0-gcm.2
Then I retagged the images retag() {
docker pull $1 && docker tag $1 $2 && docker push $2
}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager:{google-review,1.1.0-gcm.2}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager/cert-manager-acmesolver:{google-review,1.1.0-gcm.2}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager/cert-manager-cainjector:{google-review,1.1.0-gcm.2}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager/cert-manager-webhook:{google-review,1.1.0-gcm.2}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager/cert-manager-google-cas-issuer:{google-review,1.1.0-gcm.2}
retag gcr.io/jetstack-public/jetstack-secure-for-cert-manager/preflight:{google-review,1.1.0-gcm.2}
retag gcr.io/cloud-marketplace-tools/metering/ubbagent:latest gcr.io/jetstack-public/jetstack-secure-for-cert-manager/ubbagent:1.1.0-gcm.2 Finally I did (still on the branch... I know, not good) git tag 1.1.0-gcm.2
git push --tags Then I updated the version on the UI and clicked "Submit for review". |
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Both the google cas issuer's deployment, cert-manager and preflight were using the same deployment name. The issue was created when we chose to use the same nameOverride for all the subcharts. In jetstack-secure-gcm/charts/google-cas-issuer/templates/deployment.yaml: kind: Deployment metadata: name: supertestapp-jetstack-secure-gcm-controller namespace: "jetstack-secure" labels: helm.sh/chart: google-cas-issuer-1.0.0 app.kubernetes.io/name: jetstack-secure-gcm app.kubernetes.io/instance: supertestapp app.kubernetes.io/component: "controller" app.kubernetes.io/version: "0.1.0" app.kubernetes.io/managed-by: Helm In jetstack-secure-gcm/charts/cert-manager/templates/deployment.yaml: apiVersion: apps/v1 kind: Deployment metadata: name: supertestapp-jetstack-secure-gcm namespace: "jetstack-secure" labels: app: jetstack-secure-gcm app.kubernetes.io/name: jetstack-secure-gcm app.kubernetes.io/instance: supertestapp app.kubernetes.io/managed-by: Helm app.kubernetes.io/component: "controller" helm.sh/chart: cert-manager-v1.1.0 In jetstack-secure-gcm/charts/preflight/templates/deployment.yaml: apiVersion: apps/v1 kind: Deployment metadata: name: supertestapp-jetstack-secure-gcm namespace: "jetstack-secure" labels: helm.sh/chart: preflight-0.1.0 app.kubernetes.io/name: jetstack-secure-gcm app.kubernetes.io/instance: supertestapp app.kubernetes.io/version: "v0.1.27" app.kubernetes.io/managed-by: Helm Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
…441c-8809-ac693054716e Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Purpose: have the correct app.kubernetes.io/name: .Chart.Name across all objects so that the Application object can "wrangle" all the Kubernetes components using its label selector. Signed-off-by: Maël Valais <[email protected]>
2234ff1
to
8255d97
Compare
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
8255d97
to
578e7a4
Compare
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
I have cut another release, My plan is to click "Submit for review" in a few minutes, and have Google review step by step processfirst I built
Finally, I did git tag 1.1.0-gcm.3 And I went to the UI, updated the image and "Save" and Submit for review. |
Signed-off-by: Maël Valais <[email protected]>
I would get the error: % kubectl -n $NAMESPACE apply -f agent-config.yaml the namespace from the provided object "jetstack-secure" does not match the namespace "test-1". You must pass '--namespace=jetstack-secure' to perform this operation. the namespace from the provided object "jetstack-secure" does not match the namespace "test-1". You must pass '--namespace=jetstack-secure' to perform this operation. I also fixed the rollout command, since we changed the name of the deployment. I wish the preflight deployment had an label such as: app.kubernetes.io/component: preflight That would be very helpful! Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
df2d76d
to
e1300dc
Compare
The preflight agent was unable to list and get the following objects: services replicasets statefulsets jobs pods daemonsets ingresses deployments cronjobs Signed-off-by: Maël Valais <[email protected]>
e1300dc
to
63f7ff4
Compare
Signed-off-by: Maël Valais <[email protected]>
Signed-off-by: Maël Valais <[email protected]>
…h secrets Signed-off-by: Maël Valais <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @maelvls
Just a few comments and nits, but I know that this has already been deployed, so I'll add lgtm and hold so that you can decide when it gets merged.
/lgtm
/hold
**Note:** the preflight deploymnent is expected to be failing when the | ||
application is first deployed. After registering your cluster on | ||
<https://platform.jetstack.io>, the deployment will start working. To register your cluster, keep reading the [next section](#step-2-log-into-the-jetstack-secure-dashboard). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
**Note:** the preflight deploymnent is expected to be failing when the | |
application is first deployed. After registering your cluster on | |
<https://platform.jetstack.io>, the deployment will start working. To register your cluster, keep reading the [next section](#step-2-log-into-the-jetstack-secure-dashboard). | |
**Note:** the preflight deployment is expected to be failing when the | |
application is first deployed. After registering your cluster on | |
<https://platform.jetstack.io>, the deployment will start working. To register your cluster, keep reading the [next section](#step-2-log-into-the-jetstack-secure-dashboard). |
@@ -185,8 +189,8 @@ gcloud container clusters get-credentials --zone=$LOCATION $CLUSTER | |||
You can then apply the Jetstack Secure agent configuration to your cluster: | |||
|
|||
```sh | |||
kubectl -n $NAMESPACE apply -f agent-config.yaml | |||
kubectl -n $NAMESPACE rollout restart deploy jetstack-secure-preflight | |||
cat agent-config.yaml | sed '/namespace:/d' | kubectl -n $NAMESPACE apply -f- |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit:
cat agent-config.yaml | sed '/namespace:/d' | kubectl -n $NAMESPACE apply -f- | |
sed '/namespace:/d' agent-config.yaml | kubectl -n $NAMESPACE apply -f- |
kubectl -n $NAMESPACE apply -f agent-config.yaml | ||
kubectl -n $NAMESPACE rollout restart deploy jetstack-secure-preflight | ||
cat agent-config.yaml | sed '/namespace:/d' | kubectl -n $NAMESPACE apply -f- | ||
kubectl -n $NAMESPACE rollout restart $(kubectl -n $NAMESPACE get deploy -oname | grep preflight) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit I thought it might be possible to use kubectl rollout restart deployment --selector app.kubernetes.io/name=preflight
but it doesn't support the --selector
flag.
The kubectl scale
command does.
Did we discuss perhaps deploying preflight with replicas=0 ? I can't remember why we decided against it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We discussed having two separate behaviours: one for the tests, one for the normal deployments.
- When running the smoke-test, we set replica=0
- When running normally (e.g., one click deployment through the marketplace UI), the preflight deployment would be set to replica=1 (= purposefully failing)
I don't really like the idea of letting the preflight deployment in a failing mode "by default", e.g. the user would immediately see a failing deployment after deploying:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll open an issue about this.
docker run -it --rm -v "$(pwd)":/tmp frapsoft/openssl genrsa -out /tmp/ca.key 2048 | ||
docker run -it --rm -v "$(pwd)":/tmp frapsoft/openssl req -x509 -new -nodes -key /tmp/ca.key -subj "/CN=example" -reqexts v3_req -extensions v3_ca -out /tmp/ca.crt | ||
kubectl create secret tls example-ca-key-pair --cert=ca.crt --key=ca.key |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's possible to use a cert-manager self-signed Issuer to create the CA cert and then reference that from another CA Issuer.
That might be neater than using openssl from a non-jetstack Docker image.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Initially I tried the SelfSignedIssuer but I could not figure it out... I guess I should double down on that 😅
If that's OK, I will /unhold and do this change in another PR
I'll add that to my todo
|
||
## Prerequisites | ||
|
||
- Kubernetes 1.11+ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should update this, in cert-manager repo.
@@ -9,17 +9,25 @@ metadata: | |||
app.kubernetes.io/name: "{{ .Release.Name }}" | |||
annotations: | |||
marketplace.cloud.google.com/deploy-info: '{"partner_id": "partner", "product_id": "jetstack-secure", "partner_name": "Jetstack"}' | |||
kubernetes-engine.cloud.google.com/icon: >- | |||
 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, that's how it's done!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
had to dig into click-to-deploy to find this piece of the Application API 😅
@@ -48,6 +48,7 @@ Selector labels | |||
{{- define "preflight.selectorLabels" -}} | |||
app.kubernetes.io/name: {{ include "preflight.name" . }} | |||
app.kubernetes.io/instance: {{ .Release.Name }} | |||
app.kubernetes.io/component: preflight |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit. Are we calling it preflight, or are we calling it jetstack-secure-agent
, or somthing else?
I guess preflight makes sense until we change the name of the chart.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am quite confused by which name I should be employing: in places, I call it the "Jetstack Secure Platform agent", and sometimes I default to "the preflight agent".
@charlieegan3 thoughts?
app.kubernetes.io/instance: "{{ .Release.Name | trunc 63 | trimSuffix "-" }}" | ||
app.kubernetes.io/component: ubbagent |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can I wondered if we could use more descriptive values for these component names, e.g. Google Cloud Marketplace Billing Agent
....
BUT WAIT why is this still here as a separate deployment, if you have now deployed the ubbagent as a cert-manager side-car?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
...ah, this isn't the deployment, but the config for ubbagent...ignore me.
I see the deployment is deleted below.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, I moved it to the cert-manager deployment itself instead of having it qs q separate deployment. Apologies for the messy PR :-(
/unhold I created #40 with the PR comment fixes. |
Signed-off-by: Maël Valais <[email protected]> Co-authored-by: Richard Wall <[email protected]>
As Richard pointed out, there is no need to use openssl (and a Docker image of openssl that is not jetstack-branded) when we can simply use a self-signed issuer for the same purpose. Signed-off-by: Maël Valais <[email protected]> Co-authored-by: Richard Wall <[email protected]>
Fixes for the PR comments in #35
In this PR, I fix a couple of things
jetstack-public
in order to rungcloud builds submit
, otherwise the verify step will fail (see "hardcoded" in cloudbuild.yml)