-
Notifications
You must be signed in to change notification settings - Fork 2
Use jetstack public to build and fix Application wrangling #35
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
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.2Finally I did (still on the branch... I know, not good) git tag 1.1.0-gcm.2
git push --tagsThen I updated the version on the UI and clicked "Submit for review". |
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
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 <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
…441c-8809-ac693054716e Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
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 <mael@vls.dev>
2234ff1 to
8255d97
Compare
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
8255d97 to
578e7a4
Compare
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
|
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.3And I went to the UI, updated the image and "Save" and Submit for review. |
Signed-off-by: Maël Valais <mael@vls.dev>
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 <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
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 <mael@vls.dev>
e1300dc to
63f7ff4
Compare
Signed-off-by: Maël Valais <mael@vls.dev>
Signed-off-by: Maël Valais <mael@vls.dev>
…h secrets Signed-off-by: Maël Valais <mael@vls.dev>
wallrj
left a comment
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). |
| ```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.
| 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 😅
| {{- 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/component: ubbagent | ||
| app.kubernetes.io/name: "{{ .Chart.Name | trunc 63 | trimSuffix "-" }}" | ||
| 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 <mael@vls.dev> Co-authored-by: Richard Wall <richard.wall@jetstack.io>
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 <mael@vls.dev> Co-authored-by: Richard Wall <richard.wall@jetstack.io>
Fixes for the PR comments in #35


In this PR, I fix a couple of things
jetstack-publicin order to rungcloud builds submit, otherwise the verify step will fail (see "hardcoded" in cloudbuild.yml)