0%
DevOps sur AWS : Guide Complet

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
InSkillCoach

À 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

Lien copié !