Skip to content
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

Operator Enhancement #560

Merged
merged 3 commits into from
Jul 22, 2024
Merged

Conversation

MUzairS15
Copy link

Description

This PR fixes #

  1. Initialise logging for meshery-operator.
  2. Ensures the operator redeploys the controllers, if they are deleted or their status isn't Running (k8s world status)
  3. Adds health check for MeshSync

Notes for Reviewers

Signed commits

  • Yes, I signed my commits.

@MUzairS15
Copy link
Author

TODO: Replace logging with meshkit logger, redefine errors to be meshkit-errors.

@MUzairS15
Copy link
Author

2.mov

@MUzairS15 MUzairS15 requested a review from leecalcote July 18, 2024 19:24
@@ -67,7 +68,9 @@ func (r *BrokerReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctr
// Check if Broker controller deployed
result, err := r.reconcileBroker(ctx, true, baseResource, req)
if err != nil {
return ctrl.Result{}, ErrReconcileBroker(err)
err = ErrReconcileBroker(err)
r.Log.Error(err, "broker reconcilation failed")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reconciliation failures means what?

@@ -79,18 +82,24 @@ func (r *BrokerReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctr
// Get broker endpoint
err = brokerpackage.GetEndpoint(ctx, baseResource, r.Clientset, r.KubeConfig.Host)
if err != nil {
return ctrl.Result{}, ErrGetEndpoint(err)
err = ErrGetEndpoint(err)
r.Log.Error(err, "unable to get the broker endpoint")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

meaning that the endpoint is undefined or that a network-based attempt failed?

}

// Patch the broker resource
patch, err := utils.Marshal(baseResource)
if err != nil {
return ctrl.Result{}, ErrUpdateResource(err)
err = ErrUpdateResource(err)
r.Log.Error(err, "unable to update broker resource")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Meaning that the resource couldn't be found or that it is present but the operator doesn't have permission or something else?

}

err = r.Status().Patch(ctx, baseResource, client.RawPatch(types.MergePatchType, []byte(patch)))
if err != nil {
return ctrl.Result{}, ErrUpdateResource(err)
err = ErrUpdateResource(err)
r.Log.Error(err, "unable to update broker resource")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Meaning that the configuration was rejected from Kube API or that the resource isn't present or that the requested configuration was missing or invalid or what?

@@ -39,53 +39,53 @@ const (

// Error definitions
func ErrGetMeshsync(err error) error {
return errors.New(ErrGetMeshsyncCode + ":" + "Unable to get meshsync resource")
return errors.New(ErrGetMeshsyncCode + ":" + "Unable to get meshsync resource" + err.Error())
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Meaning that the custom resource was never created?

Copy link
Member

@leecalcote leecalcote left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As a user troubleshooting Meshery deployment, I'm not confident that I would know what to do when seeing these errors.

@leecalcote leecalcote requested a review from innocentrda July 18, 2024 19:53
@leecalcote
Copy link
Member

@innocentrda, your feedback here is helpful.

@leecalcote leecalcote added the area/lifecycle Lifecycle management (install, uninstall, configure) related label Jul 18, 2024
@leecalcote
Copy link
Member

Is there an adjoining addition to the https://docs.meshery.io/guides/troubleshooting/meshery-operator-meshsync guide?

@innocentrda
Copy link

As a user troubleshooting Meshery deployment, I'm not confident that I would know what to do when seeing these errors.

That's true. It's a good improvement to see those errors but being a bit detailed on why those errors and what to do can be helpful.

@MUzairS15 MUzairS15 changed the title M uzair s15/operator/logs Operator Enhancement Jul 19, 2024
@MUzairS15 MUzairS15 merged commit 5a3ddc8 into meshery:master Jul 22, 2024
5 of 6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/lifecycle Lifecycle management (install, uninstall, configure) related
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants