DevOps sur AWS : Guide Complet
Découvrez les services AWS pour l'automatisation et l'orchestration DevOps.
I
InSkillCoach
· min
DevOps sur AWS : Guide Complet
Découvrez les services AWS pour l’automatisation et l’orchestration DevOps.
1. CI/CD avec AWS CodePipeline
Configuration du Pipeline
# Exemple de configuration CodePipeline
import boto3
def create_codepipeline():
codepipeline = boto3.client('codepipeline')
pipeline_config = {
'name': 'MonPipeline',
'roleArn': 'arn:aws:iam::account:role/service-role/AWSCodePipelineServiceRole',
'stages': [
{
'name': 'Source',
'actions': [
{
'name': 'Source',
'actionTypeId': {
'category': 'Source',
'owner': 'AWS',
'provider': 'CodeCommit',
'version': '1'
},
'configuration': {
'RepositoryName': 'mon-repo',
'BranchName': 'main'
},
'outputArtifacts': [
{
'name': 'SourceOutput'
}
]
}
]
},
{
'name': 'Build',
'actions': [
{
'name': 'Build',
'actionTypeId': {
'category': 'Build',
'owner': 'AWS',
'provider': 'CodeBuild',
'version': '1'
},
'configuration': {
'ProjectName': 'MonProjetBuild'
},
'inputArtifacts': [
{
'name': 'SourceOutput'
}
],
'outputArtifacts': [
{
'name': 'BuildOutput'
}
]
}
]
}
]
}
response = codepipeline.create_pipeline(**pipeline_config)
return response['pipeline']['name']
Configuration CodeBuild
# Exemple de configuration CodeBuild
def setup_codebuild():
codebuild = boto3.client('codebuild')
project_config = {
'name': 'MonProjetBuild',
'source': {
'type': 'CODECOMMIT',
'location': 'https://git-codecommit.region.amazonaws.com/v1/repos/mon-repo',
'gitCloneDepth': 1
},
'artifacts': {
'type': 'NO_ARTIFACTS'
},
'environment': {
'type': 'LINUX_CONTAINER',
'image': 'aws/codebuild/amazonlinux2-x86_64-standard:4.0',
'computeType': 'BUILD_GENERAL1_SMALL'
},
'serviceRole': 'arn:aws:iam::account:role/service-role/AWSCodeBuildServiceRole'
}
response = codebuild.create_project(**project_config)
return response['project']['name']
2. Infrastructure as Code avec AWS CloudFormation
Création de Stack
# Exemple de création de stack CloudFormation
def create_cloudformation_stack():
cloudformation = boto3.client('cloudformation')
template = {
'AWSTemplateFormatVersion': '2010-09-09',
'Description': 'Stack de développement',
'Resources': {
'MyEC2Instance': {
'Type': 'AWS::EC2::Instance',
'Properties': {
'InstanceType': 't2.micro',
'ImageId': 'ami-0c55b159cbfafe1f0',
'Tags': [
{
'Key': 'Name',
'Value': 'InstanceDev'
}
]
}
}
}
}
response = cloudformation.create_stack(
StackName='MonStackDev',
TemplateBody=json.dumps(template),
Parameters=[
{
'ParameterKey': 'Environment',
'ParameterValue': 'Development'
}
]
)
return response['StackId']
Mise à Jour de Stack
# Exemple de mise à jour de stack
def update_cloudformation_stack():
cloudformation = boto3.client('cloudformation')
template = {
'AWSTemplateFormatVersion': '2010-09-09',
'Description': 'Stack de développement mis à jour',
'Resources': {
'MyEC2Instance': {
'Type': 'AWS::EC2::Instance',
'Properties': {
'InstanceType': 't2.small',
'ImageId': 'ami-0c55b159cbfafe1f0',
'Tags': [
{
'Key': 'Name',
'Value': 'InstanceDev'
}
]
}
}
}
}
response = cloudformation.update_stack(
StackName='MonStackDev',
TemplateBody=json.dumps(template)
)
return response['StackId']
3. Gestion des Conteneurs avec Amazon ECS
Configuration du Cluster
# Exemple de configuration ECS
def setup_ecs_cluster():
ecs = boto3.client('ecs')
# Création du cluster
cluster = ecs.create_cluster(
clusterName='MonCluster',
capacityProviders=['FARGATE'],
defaultCapacityProviderStrategy=[
{
'capacityProvider': 'FARGATE',
'weight': 1
}
]
)
# Définition de la tâche
task_definition = ecs.register_task_definition(
family='MonApplication',
networkMode='awsvpc',
requiresCompatibilities=['FARGATE'],
cpu='256',
memory='512',
executionRoleArn='arn:aws:iam::account:role/ecsTaskExecutionRole',
containerDefinitions=[
{
'name': 'MonContainer',
'image': 'mon-image:latest',
'portMappings': [
{
'containerPort': 80,
'protocol': 'tcp'
}
],
'essential': True
}
]
)
return {
'cluster_arn': cluster['cluster']['clusterArn'],
'task_definition_arn': task_definition['taskDefinition']['taskDefinitionArn']
}
Déploiement de Service
# Exemple de déploiement de service ECS
def deploy_ecs_service():
ecs = boto3.client('ecs')
service = ecs.create_service(
cluster='MonCluster',
serviceName='MonService',
taskDefinition='MonApplication',
desiredCount=2,
launchType='FARGATE',
networkConfiguration={
'awsvpcConfiguration': {
'subnets': ['subnet-xxxxx'],
'securityGroups': ['sg-xxxxx'],
'assignPublicIp': 'ENABLED'
}
}
)
return service['service']['serviceArn']
4. Monitoring avec AWS CloudWatch
Configuration des Métriques
# Exemple de configuration CloudWatch
def setup_cloudwatch_monitoring():
cloudwatch = boto3.client('cloudwatch')
# Création d'une alarme
alarm = cloudwatch.put_metric_alarm(
AlarmName='CPUUtilization',
MetricName='CPUUtilization',
Namespace='AWS/EC2',
Statistic='Average',
Period=300,
EvaluationPeriods=1,
Threshold=80,
ComparisonOperator='GreaterThanThreshold',
AlarmActions=['arn:aws:sns:region:account:MonTopic']
)
# Configuration des logs
log_group = cloudwatch.create_log_group(
logGroupName='/aws/ecs/MonApplication',
retentionInDays=30
)
return {
'alarm_name': alarm['AlarmArn'],
'log_group': log_group['logGroupName']
}
Configuration des Dashboards
# Exemple de création de dashboard
def create_cloudwatch_dashboard():
cloudwatch = boto3.client('cloudwatch')
dashboard_body = {
'widgets': [
{
'type': 'metric',
'x': 0,
'y': 0,
'width': 12,
'height': 6,
'properties': {
'metrics': [
['AWS/EC2', 'CPUUtilization', 'InstanceId', 'i-xxxxx']
],
'period': 300,
'stat': 'Average',
'region': 'region',
'title': 'Utilisation CPU'
}
}
]
}
response = cloudwatch.put_dashboard(
DashboardName='MonDashboard',
DashboardBody=json.dumps(dashboard_body)
)
return response['DashboardArn']
5. Gestion des Secrets avec AWS Secrets Manager
Configuration des Secrets
# Exemple de gestion des secrets
def manage_secrets():
secretsmanager = boto3.client('secretsmanager')
# Création d'un secret
secret = secretsmanager.create_secret(
Name='MonSecret',
SecretString=json.dumps({
'username': 'admin',
'password': 'secret123'
}),
Description='Secret pour l\'application'
)
# Récupération du secret
get_secret = secretsmanager.get_secret_value(
SecretId='MonSecret'
)
return {
'secret_arn': secret['ARN'],
'secret_value': json.loads(get_secret['SecretString'])
}
Rotation des Secrets
# Exemple de rotation des secrets
def rotate_secret():
secretsmanager = boto3.client('secretsmanager')
# Configuration de la rotation
rotation = secretsmanager.rotate_secret(
SecretId='MonSecret',
RotationRules={
'AutomaticallyAfterDays': 30
}
)
return rotation['ARN']
Conclusion
Points clés à retenir :
- Automatiser le déploiement avec CodePipeline
- Gérer l’infrastructure avec CloudFormation
- Orchestrer les conteneurs avec ECS
- Surveiller avec CloudWatch
- Sécuriser les secrets
Recommandations :
- Utiliser l’infrastructure as code
- Mettre en place des pipelines CI/CD
- Automatiser les déploiements
- Surveiller les performances
- Gérer les secrets de manière sécurisée
À propos de InSkillCoach
Expert en formation et technologies
Coach spécialisé dans les technologies avancées et l'IA, porté par GNeurone Inc.
Certifications:
- AWS Certified Solutions Architect – Professional
- Certifications Google Cloud
- Microsoft Certified: DevOps Engineer Expert
- Certified Kubernetes Administrator (CKA)
- CompTIA Security+
979
89
Commentaires
Les commentaires sont alimentés par GitHub Discussions
Connectez-vous avec GitHub pour participer à la discussion