Repository Management¶
This document explains how Argo CD Repository secrets are synchronized between the principal (control plane) and agents (workload clusters).
Overview¶
In Argo CD Agent, Git repository credentials are stored as Kubernetes Secrets with the label argocd.argoproj.io/secret-type: repository. Repository management varies by agent mode:
- Managed agents: Repositories are created on the control plane and distributed to agents that need them.
- Autonomous agents: Repositories are created and managed locally on the workload cluster. The agents will not sync them back to the control plane.
Managed Agent Mode¶
In managed mode, repositories are created on the control plane and automatically distributed to workload clusters based on AppProject configuration and agent matching patterns. Only project-scoped repositories are reconciled by the principal.
Creating Repositories¶
Repository secrets must be created in the argocd installation namespace on the control plane cluster with proper project association to enable distribution to managed agents.
Requirements for a repository secret to be reconciled by the principal:
- The secret has label
argocd.argoproj.io/secret-type: repository - The secret contains a non-empty
projectfield in.data/stringData - The secret resides in the Argo CD installation namespace (e.g.,
argocd)
Repository-to-Agent Distribution Logic¶
The principal distributes a repository secret to a managed agent using a two-step matching process:
- Project Association: Repository must include a
projectfield referencing an existing AppProject - Pattern Matching: Agent name must match both:
- At least one destination pattern via
.spec.destinations(eithernameor aserverURL that includes?agentName=<pattern>;*is allowed) - At least one pattern in the AppProject's
.spec.sourceNamespacesfields
Learn more about AppProject matching logic in the AppProjects guide.
Example: Repository Distribution Setup¶
First, create an AppProject that defines which agents should receive repositories:
apiVersion: argoproj.io/v1alpha1
kind: AppProject
metadata:
name: backend-services
namespace: argocd
spec:
# Agents matching these patterns can source Applications
sourceNamespaces:
- "backend-*"
- "api-*"
destinations:
# Applications can deploy to these agent clusters
- name: "backend-*"
namespace: "production"
server: "*"
- name: "api-*"
namespace: "staging"
server: "*"
sourceRepos:
- "https://github.com/myorg/*"
Then create a repository secret associated with this project:
apiVersion: v1
kind: Secret
metadata:
name: backend-repo
namespace: argocd
labels:
argocd.argoproj.io/secret-type: repository
type: Opaque
stringData:
type: git
url: https://github.com/myorg/backend-services.git
project: backend-services # Associates with AppProject above
This repository will be distributed to agents named:
backend-prod(matchesbackend-*in both sourceNamespaces and destinations)backend-staging(matchesbackend-*in both sourceNamespaces and destinations)api-production(matchesapi-*in both sourceNamespaces and destinations)
But not to agents like:
frontend-prod(doesn't match any patterns above)ops-eu(doesn't match any patterns above)
Agent-Side Repository Processing¶
When a repository secret is sent to a managed agent, it undergoes processing:
- Local Creation: Repository secret is created in the agent's argocd installation namespace
- Metadata Preservation: Original repository configuration (URL, credentials, etc.) is preserved
- Project Context: Repository remains associated with the original project name
- Source UID Tracking: Agent adds a source UID annotation to track the principal as source
- Change Reconciliation: Manual changes to managed repositories on agents are reverted to match the principal
Repository Lifecycle in Managed Mode¶
- Creation: Repository secrets created on the principal are automatically sent to matching agents
- Updates: Changes to repository secrets on the principal are propagated to all agents that received them
- Deletion: Deleting a repository secret on the principal removes it from all agents
- Project Changes: Updating AppProject patterns can change which agents receive repositories:
- New matching agents receive the repository
- Agents that no longer match will have the repository removed automatically
Automatic Cleanup
When AppProject patterns change and an agent no longer matches, repositories are automatically removed from that agent on the next sync.
Pattern Matching
Agent matching uses glob patterns and supports both destination name and destination server (with ?agentName=). Deny patterns prefixed with ! are supported.
Common examples:
- * - matches all agents
- prod-* - matches agents starting with "prod-"
- !dev-* - excludes agents starting with "dev-"
Autonomous Agent Mode¶
In autonomous mode, repositories are created and managed locally on the workload cluster. Repository credentials remain completely isolated to each agent cluster with no synchronization to the principal.
Creating Repositories for Autonomous Agents¶
Repository secrets are created directly in the argocd installation namespace on the autonomous agent cluster. These repositories are immediately available to local Argo CD Applications and do not require project scoping for basic functionality.
Local Repository Management¶
Autonomous agents handle repository secrets entirely within their local cluster:
- Local Creation: Repository secrets are created directly on the agent cluster
- Immediate Availability: Repositories are immediately usable by local Argo CD Applications
- No Distribution: Repositories remain isolated to the specific agent cluster
- Independent Management: Each agent manages its own set of repository credentials
Example: Creating a Repository on an Autonomous Agent¶
apiVersion: v1
kind: Secret
metadata:
name: frontend-repo
namespace: argocd
labels:
argocd.argoproj.io/secret-type: repository
type: Opaque
stringData:
type: git
url: https://github.com/myorg/frontend-app.git
username: deploy-user
password: ghp_xyz789token
# Note: project field optional for autonomous agents
# Only needed if associating with local AppProjects
Local Project Association¶
While not required for basic functionality, repositories on autonomous agents can still be associated with local AppProjects:
stringData:
# ... other repository fields
project: local-frontend-project # References local AppProject
Repository Lifecycle in Autonomous Mode¶
- Creation: Create repository secrets directly on the agent cluster
- Updates: Modify repository secrets on the agent cluster; changes take effect immediately
- Deletion: Delete repository secrets on the agent cluster; Applications using the repository will lose access
- Isolation: Repository changes on one autonomous agent do not affect other agents or the principal
Security Considerations for Autonomous Agents¶
Since repository credentials remain local to each agent cluster:
- Credential Isolation: Each agent can use different credentials for the same repository
- Independent Rotation: Repository credentials can be rotated independently on each agent
- Local RBAC: Repository access is controlled entirely by local Kubernetes RBAC
- No Central Visibility: Principal cluster has no visibility into autonomous agent repository configurations
Repository Independence
Repository credentials on autonomous agents are completely independent. The same repository URL can use different credentials on different agent clusters.
Troubleshooting¶
Repository Not Distributed to Agents (Managed Mode)¶
If a repository secret created on the principal doesn't appear on managed agents:
Check Label, Namespace and Project Association¶
Ensure the repository:
- Has label
argocd.argoproj.io/secret-type=repository - Lives in the Argo CD namespace on the principal (e.g.,
argocd) - Has a valid, non-empty
projectfield:
# Check if project field exists
kubectl get secret my-repo -n argocd -o jsonpath='{.data.project}' | base64 -d
# If no output, the repository is missing the project field
# Add it using:
kubectl patch secret my-repo -n argocd --type merge -p '{
"stringData": {
"project": "my-project-name"
}
}'
Verify AppProject Configuration¶
Check that the AppProject exists and has correct patterns:
# Check specific AppProject configuration
kubectl get appproject my-project -n argocd -o yaml
Verify that:
- The AppProject referenced by the repository exists
- Agent names match patterns in both
.spec.destinations(eithernameorserverwith?agentName=) and.spec.sourceNamespaces - Patterns use correct glob syntax, including any deny patterns (
!pattern) you intend
Check Principal Logs¶
Look for repository processing messages on the principal:
kubectl logs -n argocd deployment/argocd-agent-principal
Verify Agent Connectivity¶
Ensure agents are connected and processing events:
kubectl logs -n argocd deployment/argocd-agent
Stale Repository Data¶
If agents have outdated repository information:
# Check source UID annotation on agent
kubectl get secret my-repo -n argocd -o jsonpath='{.metadata.annotations.argocd\.argoproj\.io/source-uid}'
# Restart agent to force resync
kubectl rollout restart -n argocd deployment/argocd-agent
Migration and Recovery¶
Recovering from Principal Loss¶
If the principal cluster is lost, autonomous agents continue working normally. For managed agents:
- Repositories remain functional on agents until credentials expire
- New principal cluster needs repository secrets recreated
- Agents will reconnect and receive repositories based on AppProject patterns
For more information about Argo CD Agent configuration and other features, see: