https://www.androidpolice.com/twitter-dark-mode-follow-system-settings/
Le groupe français fera son entrée en Bourse le 15 octobre prochain. Pour l'occasion, il entend lever jusqu'à 400 millions d'euros. La promesse ? Porter son revenu annuel à 1,6 milliard d'euros en 2025.
https://www.viget.com/articles/how-weve-avoided-ux-disillusionment/
https://www.smashingmagazine.com/2021/10/autofill-dark-pattern/
La fusion avec le réseau Crédit du Nord entraînera la suppression de 3700 emplois. Sur le plan RH, cette opération se précise aujourd'hui. Le groupe Société Générale engage une restructuration de grandes ampleurs qui va transformer son organisation dans la banque de détail.
Depuis la pandémie, de plus en plus d’entreprises cherchent de nouvelles solutions de gestion des voyages. Pour répondre à leur demande, TripActions lève 275 millions de dollars en série F auprès de Greenoaks, avec la participation d’Elad Gil, de Base Partners et de tous les principaux investisseurs déjà présents. La startup basée à Palo Alto …
L’article Voyages d’affaires : TripActions lève 275 millions de dollars auprès de Greenoaks est apparu en premier sur FrenchWeb.fr.
https://speckyboy.com/in-web-design-easier-doesnt-always-mean-better/
https://uxdesign.cc/offboarding-saying-goodbye-with-grace-942cf010c223
https://www.fastcompany.com/90685137/3-common-assumptions-that-lead-to-bad-design
Need inspiration for an upcoming web design project? Want to learn how to add live chat functionality to your site, or which trends you should be aware of as you pursue new projects? Leading web design blogs could be the solution to your problems. Just as marketers follow posts on websites like Search Engine Land […]
The post 11 Must-Follow Web Design Blogs first appeared on Webdesigner Depot.
Le langage Google App Script peut être un formidable moyen de gagner du temps pour les référenceurs. Tour d'horizon des tâches qu'il est possible de déléguer à la machine.
The typeface of any design is a crucial element that needs specific attention. It can elevate the design silently or take the whole design down if you are not being focused. Some font styles have unique essence and nature to give any design the perfect finishing touch. For example, the Didone typeface is one of […]
The post 23 Modern Didone Fonts to Use in Your Designs first appeared on Line25.La start-up fondée par un ancien d'Adyoulike veut convertir près de 200 000 e-commerçants au retail media.
Les montants investis s'élèvent à 10,5 milliards d'euros lors des six premiers mois de l'année, soit une progression de 35% par rapport à la même période de 2020.
L’article En France, le capital-investissement atteint des records au premier semestre est apparu en premier sur FrenchWeb.fr.
Vous avez sûrement déjà entendu parler de Docker, si ce n'est déjà utilisé.
Docker peut considérablement vous simplifier la vie, sécuriser, harmoniser votre environnement de développement ou de production, ainsi que faciliter le travail en équipe... après l'avoir apprivoisé.
Le plan de ce tutoriel :
À la fin de cette page vous serez comme ça.
Docker n'est pas une machine virtuelle ; c'est une technologie qui orchestre des applications en conteneurs (containerisées), embarquant chacune leurs dépendances, en fonctionnant de manière isolée tout en pouvant partager des ressources et communiquer.
Même si on peut le percevoir comme une autre recette accroissant la hauteur du burger full-stack, s'y intéresser vaut le détour.
ð¥ Chez Alsacréations nous avons, après de multiples expérimentations, structuré notre propre environnement pour les projets WordPress autour de WordPlate + MySQL/MariaDB dans Docker. Cela nous permet d'avoir un modèle propre, organisé, testé, éprouvé, documenté, pour tout nouveau projet de site. #pub Si vous avez besoin d'une équipe à la pointe pour votre nouveau site ou votre refonte, contactez-nous ;) (PS : on aime aussi Vue et Nuxt).
(Illustration : Docker.com)
Lorsqu'on découvre Docker, le plus mystérieux n'est pas son fonctionnement interne. Il faut avant tout cerner la logique des quelques opérations de base :
Cette introduction est destinée à en présenter les concepts pour une prise en main rapide pour un cas simple : développer un site web (avec WordPress en option) sans avoir à installer et configurer Apache, PHP, MySQL sur sa machine ou une solution qui les regroupe telle que WAMP, MAMP, XAMPP, etc. et que l'on n'ose plus toucher ultérieurement "tant que ça marche".
Le même principe est applicable à d'autres configurations et langages (Java, Python, Node, Redis, PostgreSQL, Nginx, MongoDB...)
Identifions tout de suite les avantages majeurs de Docker :
Sans entrer dans les détails techniques, il ne s'agit pas d'émulation et il n'y a pas de comparaison possible avec VirtualBox ou VmWare. La performance de Docker selon le système utilisé est :
Si le poids des images (des applications) varie selon leur complexité, on reste loin d'une machine virtuelle complète : à partir de quelques Mo car pouvant être construites grâce à Alpine Linux, une distribution très légère (~5 Mo)... jusqu'à quelques centaines de Mo.
Docker est articulé autour de plusieurs concepts, qu'il n'est pas nécessaire de maîtriser pleinement pour commencer à s'en servir :
Si vous installez Docker sur votre machine, vous retrouverez la commande docker
dans votre Terminal (CLI) quoiqu'il arrive.
Toutes les opérations sont décrites en ligne de commande mais une fois vos containers en place vous pouvez les démarrer/arrêter en un clic avec l'interface graphique ou l'extension Visual Studio Code.
Une image est un modèle d'application, préconfigurée, embarquée dans un mini-système Linux. Docker Hub liste toutes les images disponibles publiquement au téléchargement https://hub.docker.com/search?q=&type=image ; chacune étant nommée image:tag
, avec tag représentant une version, ou une déclinaison particulière.
Exemples :
L'image hello-world
est une petite image de démonstration qui ne fait qu'afficher un message de bienvenue, pratique pour les premiers tests :
Récupérer une image existante se fait avec la commande pull
, par exemple : docker pull hello-world:latest
Exécuter cette image dans un conteneur se fait avec run
: docker run hello-world
Si on tente un run directement sans avoir pull ou sans avoir déjà une image en stock, le pull est déclenché automatiquement. On en profite.
Si on possède Docker Desktop (Windows, Mac) ou Dockstation (Linux), l'image apparaît dans le "stock" disponible en local.
L'image est notée comme étant in use (utilisée) par un un conteneur qui a aussi été créé pour l'occasion (avec un nom aléatoire) :
On peut aussi se renseigner en ligne de commande avec docker image ls
$ docker image ls
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest feb5d9fea6a5 2 weeks ago 13.3kB
À noter : lorsqu'une image a été téléchargée pour être exécutée, elle reste disponible en local. On peut nettoyer cette liste par la suite en se débarrassant des conteneurs associés : docker container prune
(supprime les conteneurs inactifs) puis docker image rm hello-world
.
Il y a toujours cette dualité : un conteneur ne peut exister l'image qui lui a donné naissance.
Cette première étape est déjà bien motivante : on peut rapidement télécharger-exécuter une application avec les avantages de base de Docker. Lançons notre premier serveur web Apache avec PHP : docker run -p 80:80 php:7.4-apache
(les noms disponibles peuvent être trouvés dans la section tags du hub Docker).
L'option -p 80:80
signifie que l'on fait correspondre le port http local à celui exposé par le conteneur (sinon on ne pourra s'y connecter, tout étant bloqué par défaut).
Et maintenant ? En se rendant à l'adresse http://localhost/ il y a une réponse du serveur... avec une erreur du type 403 Forbidden car aucun fichier n'est encore prêt à être servi. Mais nous avons bien un serveur web Apache qui tourne, équipé de PHP (croyons-le sur parole) après une seule ligne de commande. ð
Il reste maintenant à peaufiner la configuration, déterminer l'accès aux bons fichiers (du site web) et compléter par MySQL dans le cadre de cette introduction.
Il est possible de créer ses propres images, à partir de briques déjà existantes (telles que celle utilisée précédemment php:7.4-apache), complétées par des instructions de configuration.
Un Dockerfile est un fichier texte qui va dans un premier temps invoquer une image de base, avec l'instruction FROM
puis dérouler d'autres commandes propres à Docker dont la liste est présentée ci-dessous. En voici un exemple relativement parlant (surtout si vous êtes familier de la ligne de commande Linux).
# Image de base
FROM php:7.4-apache
# Port ouvert (web = 80)
EXPOSE 80
# Dossier de travail pour les commandes suivantes
WORKDIR /var/www/html
# Installation initiale de modules apache et php
RUN a2enmod headers deflate expires rewrite
RUN docker-php-ext-install mysqli
# Redémarrage d'Apache pour prendre en compte ces modifications
RUN apachectl restart
L'image obtenue nous permettra d'avoir désormais en plus : des modules Apache (headers, deflate, expires, rewrite) et un module mysqli pour PHP.
Une dizaine d'instructions existent : https://docs.docker.com/engine/reference/builder/ entre autres :
FROM
Définit l'image source (FROM php:7.4-cli
).ENV
Définit une variable d'environnement à la compilation et à l'exécution (ENV MY_VAR=kiwi
).LABEL
Ajoute une métadonnée à l'image.WORKDIR
Définit le dossier de travail pour les commandes suivantes (WORKDIR /var/www/html
).RUN
Exécute une commande à la compilation (RUN echo Hello
).CMD
Exécute une commande dans le conteneur (CMD [ "php", "./your-script.php" ]
).EXPOSE
Informe Docker que le conteneur écoute sur un port (EXPOSE 80
ou EXPOSE 80/tcp
).COPY
Copie des fichiers/répertoires depuis une source vers le filesystem de l'image. --chown
modifie les droits à la volée.ADD
Ajoute des fichiers/répertoires (y compris depuis une URL ou une extraction tar) dans le filesystem de l'image (ADD test.txt dir/
). --chown
modifie les droits à la volée.VOLUME
Crée un point de montage (VOLUME /myvol
).ENTRYPOINT
Configure un conteneur comme un exécutable.USER
Définit l'id utilisateur (UID) et groupe (GID) à utiliser lorsque l'image s'exécute et pour toute instruction suivante (RUN, CMD, ENTRYPOINT).ARG
Définit une variable que l'on peut passer au moment de la compilation avec --build-arg <varname>=<value>
.La commande build compile une nouvelle image à partir de paramètres (et dans la plupart des cas d’une autre image racine) décrits par la “recette” Dockerfile : docker build -t monserveurweb .
Le point final signifie que le fichier Dockerfile se trouve dans le dossier courant.
L'image apparaît ensuite dans la liste des images disponibles, que ce soit en ligne de commande avec docker image list
ou dans le client graphique Docker.
Pour lancer le conteneur correspondant, on utilisera docker run
(ou l'interface graphique) à partir d’un nom d'image, par exemple docker run monserveurweb
.
(Il ne faut pas faire attention ici aux warnings, c'est logique et propre à Apache car on ne lui a pas indiqué de configuration particulière)
Pour éviter d'avoir un nom généré aléatoirement, on pourra le nommer docker run --name mon-serveur-web monserveurweb
. et relancer cette commande autant de fois que nécessaire.
On constate alors que ce nouveau couple image/conteneur :
docker container stop mon-serveur-web
et supprimé avec docker container rm mon-serveur-web
lorsqu'on n'en a plus besoin, puis invoqué à nouveau plus tard, etc.La commande docker run
peut comporter un certain nombre de paramètres pour indiquer dans quelles conditions exécuter l’application (volumes de données, ports, droits, etc).
Chaque conteneur peut exposer (EXPOSE
) des ports du conteneur vers l’extérieur (l’hôte) : -p 8000:80
signifie que le conteneur "publie" son port 80 "natif" vers le port 8000 et que le navigateur s'y connecter sur http://localhost:8000 s'il est sur la même machine. Dans notre exemple initial nous avions 80:80
, si votre port 80 est déjà occupé par une autre application rien ne vous empêchera d'en choisir librement un autre. Chaque conteneur Apache invoqué pourra donc vivre sur son port 80 naturellement sans avoir besoin d'être configuré autrement.
Un lien permet de lier, ou plutôt de rendre visibles des conteneurs entre eux, par des noms choisis, sur leurs réseaux respectifs : --link db:mysql
(plus de détails à venir dans la partie compose).
Un volume est un "partage" d’un dossier local (machine hôte = votre système Linux/Windows/Mac) avec le conteneur. Il peut aussi provenir d’un service distant (ssh, s3…). Ce n’est pas une copie, c’est une synchronisation réelle sur le disque. Conteneur et hôte peuvent lire et écrire dans cet emplacement : pratique pour conserver les données utiles hors du conteneur lorsqu'il est arrêté/détruit.
Exemples : -v C:\www\mysql:/var/lib/mysql
(car dans un conteneur mysql ou mariadb, les données des bases sont par défaut dans /var/lib/mysql) ou -v /var/www/wordpress/public:/var/www/html
(car dans un conteneur apache, les fichiers sont cherchés par défaut dans /var/www/html)
On place le chemin local à gauche du séparateur :
et le chemin dans le conteneur à droite local:conteneur
Pour finir, une commande plus complète pourrait donner ceci :
docker run
-v c:\www\docker\wordpress:/var/www/html
-p 80:80
# -p 8000:80 (si on a besoin de changer le port)
# --link mysqlserver:db (on ne peut pas encore faire ça, voir ci-dessous)
monserveurweb
# ou php:7.4-apache
Cela signifie que les fichiers de votre site web (WordPress ou autre, en HTML statique ou PHP) devront être placés dans le chemin mentionné (ici c:\www\docker\wordpress) pour qu'Apache puisse les trouver et afficher la page d'installation.
Nous avons le serveur web, il nous faut ajouter la base de données MySQL (ou MariaDB).
On peut là aussi démarrer rapidement un serveur à partir de docker run
et nous n'aurons pas besoin de Dockerfile car l'image de base fournie mysql/mysql-server
par https://hub.docker.com/r/mysql/mysql-server/ ne sera pas modifiée.
Une petite différence avec l'image d'Apache : nous aurons tout de même besoin d'une variable d'environnement car MySQL nécessite d'être initialisé avec un mot de passe ; au choix :
-e MYSQL_ROOT_PASSWORD=azertybaïdjan
(explicite, mot de passe "en dur")-e MYSQL_RANDOM_ROOT_PASSWORD=yes
(mot de passe aléatoirement généré la première fois : retrouvez-le dans les logs du container, attention il faut le noter car il disparaît ensuite)Voici la commande complète :
docker run
--name mysqlserver
# --restart always (si on veut le redémarrer automatiquement)
-p 3306:3306
-v $PWD/mysql:/var/lib/mysql
-e MYSQL_ROOT_PASSWORD=azertybaïdjan
mysql/mysql-server
Ici le port 3306 standard est exposé vers l'extérieur, et $PWD
signifie "dossier courant" : ce n'est pas forcément disponible sous Windows où il faudra spécifier le chemin complet (c:...)
Si on oublie le volume (option -v
) alors les données seront stockées dans le conteneur et effacées avec lui. Attention Dino Danger.
L'option -e
passe une variable d’environnement (existe déjà nativement sous Windows, macOS, Linux) au conteneur, souvent pour le pré-configurer.
Pour le serveur MySQL : -e MYSQL_ROOT_PASSWORD=****** -e MYSQL_DATABASE=db -e MYSQL_USER=user
Pour phpmyadmin : -e UPLOAD_LIMIT=128M -e PMA_HOST=db
Ces variables sont données par la documentation officielle, exemple pour PhpMyAdmin : https://hub.docker.com/r/phpmyadmin/phpmyadmin/
Nous devons adapter la commande run du conteneur apache pour qu'il puisse utiliser un lien vers le conteneur de la base.
docker run --name mon-serveur-web -v c:\www\docker\wordpress:/var/www/html -p 80:80 --link mysqlserver:db monserveurweb
Le nom du serveur (host, hostname) à indiquer pour un script PHP souhaitant se connecter à MySQL, ou pour l'installation de WordPress, deviendra "db".
Tout cela est bien beau, avec phpmyadmin pour administrer le serveur c'est encore mieux.
Lançons docker run --name pma --link mysqlserver:db -p 8080:80 -e PMA_HOST=db -e UPLOAD_LIMIT=128M phpmyadmin
Toutes les options ont déjà été décrites précédemment, la nouveauté est l'usage de --link
qui va indiquer que lorsque phpmyadmin tentera de se connecter au serveur nommé "db" (précisé par PMA_HOST), cela pointera en réalité vers l'IP interne du conteneur nommé "mysqlserver".
Nous pouvons nous y connecter via http://localhost:8080/ comme on peut le deviner avec l'option -p
utilisée.
Après cette mise en place, un constat : tous ces conteneurs sont bien pratiques, il nous a suffi de quelques d'instructions pour aboutir à un environnement complet, modulaire :
Tous les ports ouverts sont indiqués, ainsi que par la commande docker container ls
.
Une fois qu'on maîtrise ce principe, toutes les autres images Docker sont à portée de pull + run.
il nous faudrait ~~un anneau~~ une magie supplémentaire pour tous les gouverner... plutôt que de manipuler la ligne de commande pour chacun d'entre eux : cela fera l'objet d'un prochain tutoriel.
Un conteneur est surtout le code d’application, ne devrait pas détenir les données du projet (ex : la base SQL, les uploads).
Tant qu'on utilise les volumes qui partagent les fichiers du système hôte (votre machine) dans un dossier précis, on conservera les données utiles “en dehors” du conteneur s'il est détruit.
Un conteneur détruit pourra être remplacé par un autre (ex : une nouvelle version de l'application) tout en accédant au volume des données qui a été préservé. C'est une philosophie : séparer proprement, et se préparer au pire, permettent d'aborder les risques plus sereinement.
Vous pourrez par exemple
gitlab-ee
édition payante vers gitlab-ce
édition gratuite)mysql-server
par mariadb
, son "équivalent" beaucoup plus libreUn mot rapide sur Alpine Linux : c'est une distribution Linux minimaliste qui a été choisie pour la plupart des images Docker en raison de son poids. Si les quelques Mo qui servent de socle sont orientés pour des utilisateurs expérimentés, rien n'empêche de les étoffer par d'autres paquets.
Il n'y a aucune obligation à maîtriser Linux (ou Alpine Linux) pour se servir de Docker. Néanmoins pouvoir exécuter des commandes en accédant au shell du conteneur est pratique pour bien des opérations.
Il y a plusieurs façons d'exécuter un conteneur, la méthode classique est de le laisser tourner en permanence en tâche de fond et de s'y connecter sur un port, par exemple avec un navigateur web pour Apache, mais on peut aussi :
-it
)docker run -it alpine /bin/sh
ls
)docker run alpine ls -l
docker exec -i mysqlserver mysqldump mabase -ulogin -ppassword | gzip >export.sql.gz
Ici mysqlserver
est le nom du conteneur et mysqldump mabase -ulogin -ppassword
est la commande qui s'exécute dans ce conteneur.
L'extension Docker est fortement recommandée pour se connecter au service Docker (Engine) de la machine et administrer les images et conteneurs, mais aussi, entre autres :
À défaut d'utiliser Docker Desktop, cette extension accomplit les tâches les plus courantes, sans quitter l'éditeur de code.
Sous Linux, pour synchroniser l’heure/fuseau horaire de l’hôte à celui du conteneur (sinon il peut y avoir un décalage de 2h en Europe), on peut ajouter un volume -v /etc/localtime:/etc/localtime:ro
(ici ro
signifie read-only c'est-à-dire lecture seule)
Si le shell par défaut est trop limité, tenter d’exécuter bash
s'il est déjà inclus dans l'image, ou on peut l'installer avec un petit apt update && apt install bash
etc. Même chose pour l'éditeur vim
si vous savez comment en sortir.
docker build -t <nomimage:tag> .
docker run --name <nomducontainer> <nomimage:tag>
(+ voir autres options)docker start <nomducontainer>
(ou stop
)docker container exec -it <nomducontainer> <lacommande>
(par exemple bash
pour ouvrir un shell)docker container ls
ou docker ps -a
docker image ls
docker container rm <nomducontainer>
docker image rm <nomdelimage>
$PWD
docker network create my-custom-net
et l'utiliser au run : --network=my-custom-net
docker stats
docker logs <nomducontainer>
docker port <nomducontainer>
docker top <nomducontainer>
docker diff <nomducontainer>
-d
: permet de détacher l'exécution du container du terminal courant-p
: permet de lier un port (local:container -p 8080:80
)-u
: permet de spécifier l'utilisateur+groupe d'exécution-v
: permet de déclarer un volume (local:container -v /var/path/to/mydata/mysql:/var/lib/mysql
)-e
: permet de passer/spécifier une variable d'environnement-i
: permet d'avoir un terminal interactif (stdin), par exemple pour entrer un mot de passe au prompt (souvent combiné avec t
)-t
: alloue un pseudo-tty--link
: permet de "lier" un hostname d'un container à un autre (par exemple un serveur mysql dans un 1er container mysqlserver
devient --link mysqlserver:db
dans le 2e, on utilise alors db
)--restart always
: indique au service Docker de redémarrer le container au boot et de le maintenir actif si Docker est lui-même relancéAstuces :
-m 256m
pour limiter la mémoire à 256 Mo--read-only
pour que le système de fichiers soit en lecture seule:ro
pour qu'il soit en lecture seuleRetrouvez l'intégralité de ce tutoriel en ligne sur Alsacreations.com
Vous avez sûrement déjà entendu parler de Docker, si ce n'est déjà utilisé.
Docker peut considérablement vous simplifier la vie, sécuriser, harmoniser votre environnement de développement ou de production, ainsi que faciliter le travail en équipe... après l'avoir apprivoisé.
Le plan de ce tutoriel :
À la fin de cette page vous serez comme ça.
Docker n'est pas une machine virtuelle ; c'est une technologie qui orchestre des applications en conteneurs (containerisées), embarquant chacune leurs dépendances, en fonctionnant de manière isolée tout en pouvant partager des ressources et communiquer.
Même si on peut le percevoir comme une autre recette accroissant la hauteur du burger full-stack, s'y intéresser vaut le détour.
ð¥ Chez Alsacréations nous avons, après de multiples expérimentations, structuré notre propre environnement pour les projets WordPress autour de WordPlate + MySQL/MariaDB dans Docker. Cela nous permet d'avoir un modèle propre, organisé, testé, éprouvé, documenté, pour tout nouveau projet de site. #pub Si vous avez besoin d'une équipe à la pointe pour votre nouveau site ou votre refonte, contactez-nous ;) (PS : on aime aussi Vue et Nuxt).
(Illustration : Docker.com)
Lorsqu'on découvre Docker, le plus mystérieux n'est pas son fonctionnement interne. Il faut avant tout cerner la logique des quelques opérations de base :
Cette introduction est destinée à en présenter les concepts pour une prise en main rapide pour un cas simple : développer un site web (avec WordPress en option) sans avoir à installer et configurer Apache, PHP, MySQL sur sa machine ou une solution qui les regroupe telle que WAMP, MAMP, XAMPP, etc. et que l'on n'ose plus toucher ultérieurement "tant que ça marche".
Le même principe est applicable à d'autres configurations et langages (Java, Python, Node, Redis, PostgreSQL, Nginx, MongoDB...)
Identifions tout de suite les avantages majeurs de Docker :
Sans entrer dans les détails techniques, il ne s'agit pas d'émulation et il n'y a pas de comparaison possible avec VirtualBox ou VmWare. La performance de Docker selon le système utilisé est :
Si le poids des images (des applications) varie selon leur complexité, on reste loin d'une machine virtuelle complète : à partir de quelques Mo car pouvant être construites grâce à Alpine Linux, une distribution très légère (~5 Mo)... jusqu'à quelques centaines de Mo.
Docker est articulé autour de plusieurs concepts, qu'il n'est pas nécessaire de maîtriser pleinement pour commencer à s'en servir :
Si vous installez Docker sur votre machine, vous retrouverez la commande docker
dans votre Terminal (CLI) quoiqu'il arrive.
Toutes les opérations sont décrites en ligne de commande mais une fois vos containers en place vous pouvez les démarrer/arrêter en un clic avec l'interface graphique ou l'extension Visual Studio Code.
Une image est un modèle d'application, préconfigurée, embarquée dans un mini-système Linux. Docker Hub liste toutes les images disponibles publiquement au téléchargement https://hub.docker.com/search?q=&type=image ; chacune étant nommée image:tag
, avec tag représentant une version, ou une déclinaison particulière.
Exemples :
L'image hello-world
est une petite image de démonstration qui ne fait qu'afficher un message de bienvenue, pratique pour les premiers tests :
Récupérer une image existante se fait avec la commande pull
, par exemple : docker pull hello-world:latest
Exécuter cette image dans un conteneur se fait avec run
: docker run hello-world
Si on tente un run directement sans avoir pull ou sans avoir déjà une image en stock, le pull est déclenché automatiquement. On en profite.
Si on possède Docker Desktop (Windows, Mac) ou Dockstation (Linux), l'image apparaît dans le "stock" disponible en local.
L'image est notée comme étant in use (utilisée) par un un conteneur qui a aussi été créé pour l'occasion (avec un nom aléatoire) :
On peut aussi se renseigner en ligne de commande avec docker image ls
$ docker image ls
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest feb5d9fea6a5 2 weeks ago 13.3kB
À noter : lorsqu'une image a été téléchargée pour être exécutée, elle reste disponible en local. On peut nettoyer cette liste par la suite en se débarrassant des conteneurs associés : docker container prune
(supprime les conteneurs inactifs) puis docker image rm hello-world
.
Il y a toujours cette dualité : un conteneur ne peut exister l'image qui lui a donné naissance.
Cette première étape est déjà bien motivante : on peut rapidement télécharger-exécuter une application avec les avantages de base de Docker. Lançons notre premier serveur web Apache avec PHP : docker run -p 80:80 php:7.4-apache
(les noms disponibles peuvent être trouvés dans la section tags du hub Docker).
L'option -p 80:80
signifie que l'on fait correspondre le port http local à celui exposé par le conteneur (sinon on ne pourra s'y connecter, tout étant bloqué par défaut).
Et maintenant ? En se rendant à l'adresse http://localhost/ il y a une réponse du serveur... avec une erreur du type 403 Forbidden car aucun fichier n'est encore prêt à être servi. Mais nous avons bien un serveur web Apache qui tourne, équipé de PHP (croyons-le sur parole) après une seule ligne de commande. ð
Il reste maintenant à peaufiner la configuration, déterminer l'accès aux bons fichiers (du site web) et compléter par MySQL dans le cadre de cette introduction.
Il est possible de créer ses propres images, à partir de briques déjà existantes (telles que celle utilisée précédemment php:7.4-apache), complétées par des instructions de configuration.
Un Dockerfile est un fichier texte qui va dans un premier temps invoquer une image de base, avec l'instruction FROM
puis dérouler d'autres commandes propres à Docker dont la liste est présentée ci-dessous. En voici un exemple relativement parlant (surtout si vous êtes familier de la ligne de commande Linux).
# Image de base
FROM php:7.4-apache
# Port ouvert (web = 80)
EXPOSE 80
# Dossier de travail pour les commandes suivantes
WORKDIR /var/www/html
# Installation initiale de modules apache et php
RUN a2enmod headers deflate expires rewrite
RUN docker-php-ext-install mysqli
# Redémarrage d'Apache pour prendre en compte ces modifications
RUN apachectl restart
L'image obtenue nous permettra d'avoir désormais en plus : des modules Apache (headers, deflate, expires, rewrite) et un module mysqli pour PHP.
Une dizaine d'instructions existent : https://docs.docker.com/engine/reference/builder/ entre autres :
FROM
Définit l'image source (FROM php:7.4-cli
).ENV
Définit une variable d'environnement à la compilation et à l'exécution (ENV MY_VAR=kiwi
).LABEL
Ajoute une métadonnée à l'image.WORKDIR
Définit le dossier de travail pour les commandes suivantes (WORKDIR /var/www/html
).RUN
Exécute une commande à la compilation (RUN echo Hello
).CMD
Exécute une commande dans le conteneur (CMD [ "php", "./your-script.php" ]
).EXPOSE
Informe Docker que le conteneur écoute sur un port (EXPOSE 80
ou EXPOSE 80/tcp
).COPY
Copie des fichiers/répertoires depuis une source vers le filesystem de l'image. --chown
modifie les droits à la volée.ADD
Ajoute des fichiers/répertoires (y compris depuis une URL ou une extraction tar) dans le filesystem de l'image (ADD test.txt dir/
). --chown
modifie les droits à la volée.VOLUME
Crée un point de montage (VOLUME /myvol
).ENTRYPOINT
Configure un conteneur comme un exécutable.USER
Définit l'id utilisateur (UID) et groupe (GID) à utiliser lorsque l'image s'exécute et pour toute instruction suivante (RUN, CMD, ENTRYPOINT).ARG
Définit une variable que l'on peut passer au moment de la compilation avec --build-arg <varname>=<value>
.La commande build compile une nouvelle image à partir de paramètres (et dans la plupart des cas d’une autre image racine) décrits par la “recette” Dockerfile : docker build -t monserveurweb .
Le point final signifie que le fichier Dockerfile se trouve dans le dossier courant.
L'image apparaît ensuite dans la liste des images disponibles, que ce soit en ligne de commande avec docker image list
ou dans le client graphique Docker.
Pour lancer le conteneur correspondant, on utilisera docker run
(ou l'interface graphique) à partir d’un nom d'image, par exemple docker run monserveurweb
.
(Il ne faut pas faire attention ici aux warnings, c'est logique et propre à Apache car on ne lui a pas indiqué de configuration particulière)
Pour éviter d'avoir un nom généré aléatoirement, on pourra le nommer docker run --name mon-serveur-web monserveurweb
. et relancer cette commande autant de fois que nécessaire.
On constate alors que ce nouveau couple image/conteneur :
docker container stop mon-serveur-web
et supprimé avec docker container rm mon-serveur-web
lorsqu'on n'en a plus besoin, puis invoqué à nouveau plus tard, etc.La commande docker run
peut comporter un certain nombre de paramètres pour indiquer dans quelles conditions exécuter l’application (volumes de données, ports, droits, etc).
Chaque conteneur peut exposer (EXPOSE
) des ports du conteneur vers l’extérieur (l’hôte) : -p 8000:80
signifie que le conteneur "publie" son port 80 "natif" vers le port 8000 et que le navigateur s'y connecter sur http://localhost:8000 s'il est sur la même machine. Dans notre exemple initial nous avions 80:80
, si votre port 80 est déjà occupé par une autre application rien ne vous empêchera d'en choisir librement un autre. Chaque conteneur Apache invoqué pourra donc vivre sur son port 80 naturellement sans avoir besoin d'être configuré autrement.
Un lien permet de lier, ou plutôt de rendre visibles des conteneurs entre eux, par des noms choisis, sur leurs réseaux respectifs : --link db:mysql
(plus de détails à venir dans la partie compose).
Un volume est un "partage" d’un dossier local (machine hôte = votre système Linux/Windows/Mac) avec le conteneur. Il peut aussi provenir d’un service distant (ssh, s3…). Ce n’est pas une copie, c’est une synchronisation réelle sur le disque. Conteneur et hôte peuvent lire et écrire dans cet emplacement : pratique pour conserver les données utiles hors du conteneur lorsqu'il est arrêté/détruit.
Exemples : -v C:\www\mysql:/var/lib/mysql
(car dans un conteneur mysql ou mariadb, les données des bases sont par défaut dans /var/lib/mysql) ou -v /var/www/wordpress/public:/var/www/html
(car dans un conteneur apache, les fichiers sont cherchés par défaut dans /var/www/html)
On place le chemin local à gauche du séparateur :
et le chemin dans le conteneur à droite local:conteneur
Pour finir, une commande plus complète pourrait donner ceci :
docker run
-v c:\www\docker\wordpress:/var/www/html
-p 80:80
# -p 8000:80 (si on a besoin de changer le port)
# --link mysqlserver:db (on ne peut pas encore faire ça, voir ci-dessous)
monserveurweb
# ou php:7.4-apache
Cela signifie que les fichiers de votre site web (WordPress ou autre, en HTML statique ou PHP) devront être placés dans le chemin mentionné (ici c:\www\docker\wordpress) pour qu'Apache puisse les trouver et afficher la page d'installation.
Nous avons le serveur web, il nous faut ajouter la base de données MySQL (ou MariaDB).
On peut là aussi démarrer rapidement un serveur à partir de docker run
et nous n'aurons pas besoin de Dockerfile car l'image de base fournie mysql/mysql-server
par https://hub.docker.com/r/mysql/mysql-server/ ne sera pas modifiée.
Une petite différence avec l'image d'Apache : nous aurons tout de même besoin d'une variable d'environnement car MySQL nécessite d'être initialisé avec un mot de passe ; au choix :
-e MYSQL_ROOT_PASSWORD=azertybaïdjan
(explicite, mot de passe "en dur")-e MYSQL_RANDOM_ROOT_PASSWORD=yes
(mot de passe aléatoirement généré la première fois : retrouvez-le dans les logs du container, attention il faut le noter car il disparaît ensuite)Voici la commande complète :
docker run
--name mysqlserver
# --restart always (si on veut le redémarrer automatiquement)
-p 3306:3306
-v $PWD/mysql:/var/lib/mysql
-e MYSQL_ROOT_PASSWORD=azertybaïdjan
mysql/mysql-server
Ici le port 3306 standard est exposé vers l'extérieur, et $PWD
signifie "dossier courant" : ce n'est pas forcément disponible sous Windows où il faudra spécifier le chemin complet (c:...)
Si on oublie le volume (option -v
) alors les données seront stockées dans le conteneur et effacées avec lui. Attention Dino Danger.
L'option -e
passe une variable d’environnement (existe déjà nativement sous Windows, macOS, Linux) au conteneur, souvent pour le pré-configurer.
Pour le serveur MySQL : -e MYSQL_ROOT_PASSWORD=****** -e MYSQL_DATABASE=db -e MYSQL_USER=user
Pour phpmyadmin : -e UPLOAD_LIMIT=128M -e PMA_HOST=db
Ces variables sont données par la documentation officielle, exemple pour PhpMyAdmin : https://hub.docker.com/r/phpmyadmin/phpmyadmin/
Nous devons adapter la commande run du conteneur apache pour qu'il puisse utiliser un lien vers le conteneur de la base.
docker run --name mon-serveur-web -v c:\www\docker\wordpress:/var/www/html -p 80:80 --link mysqlserver:db monserveurweb
Le nom du serveur (host, hostname) à indiquer pour un script PHP souhaitant se connecter à MySQL, ou pour l'installation de WordPress, deviendra "db".
Tout cela est bien beau, avec phpmyadmin pour administrer le serveur c'est encore mieux.
Lançons docker run --name pma --link mysqlserver:db -p 8080:80 -e PMA_HOST=db -e UPLOAD_LIMIT=128M phpmyadmin
Toutes les options ont déjà été décrites précédemment, la nouveauté est l'usage de --link
qui va indiquer que lorsque phpmyadmin tentera de se connecter au serveur nommé "db" (précisé par PMA_HOST), cela pointera en réalité vers l'IP interne du conteneur nommé "mysqlserver".
Nous pouvons nous y connecter via http://localhost:8080/ comme on peut le deviner avec l'option -p
utilisée.
Après cette mise en place, un constat : tous ces conteneurs sont bien pratiques, il nous a suffi de quelques d'instructions pour aboutir à un environnement complet, modulaire :
Tous les ports ouverts sont indiqués, ainsi que par la commande docker container ls
.
Une fois qu'on maîtrise ce principe, toutes les autres images Docker sont à portée de pull + run.
il nous faudrait ~~un anneau~~ une magie supplémentaire pour tous les gouverner... plutôt que de manipuler la ligne de commande pour chacun d'entre eux : cela fera l'objet d'un prochain tutoriel.
Un conteneur est surtout le code d’application, ne devrait pas détenir les données du projet (ex : la base SQL, les uploads).
Tant qu'on utilise les volumes qui partagent les fichiers du système hôte (votre machine) dans un dossier précis, on conservera les données utiles “en dehors” du conteneur s'il est détruit.
Un conteneur détruit pourra être remplacé par un autre (ex : une nouvelle version de l'application) tout en accédant au volume des données qui a été préservé. C'est une philosophie : séparer proprement, et se préparer au pire, permettent d'aborder les risques plus sereinement.
Vous pourrez par exemple
gitlab-ee
édition payante vers gitlab-ce
édition gratuite)mysql-server
par mariadb
, son "équivalent" beaucoup plus libreUn mot rapide sur Alpine Linux : c'est une distribution Linux minimaliste qui a été choisie pour la plupart des images Docker en raison de son poids. Si les quelques Mo qui servent de socle sont orientés pour des utilisateurs expérimentés, rien n'empêche de les étoffer par d'autres paquets.
Il n'y a aucune obligation à maîtriser Linux (ou Alpine Linux) pour se servir de Docker. Néanmoins pouvoir exécuter des commandes en accédant au shell du conteneur est pratique pour bien des opérations.
Il y a plusieurs façons d'exécuter un conteneur, la méthode classique est de le laisser tourner en permanence en tâche de fond et de s'y connecter sur un port, par exemple avec un navigateur web pour Apache, mais on peut aussi :
-it
)docker run -it alpine /bin/sh
ls
)docker run alpine ls -l
docker exec -i mysqlserver mysqldump mabase -ulogin -ppassword | gzip >export.sql.gz
Ici mysqlserver
est le nom du conteneur et mysqldump mabase -ulogin -ppassword
est la commande qui s'exécute dans ce conteneur.
L'extension Docker est fortement recommandée pour se connecter au service Docker (Engine) de la machine et administrer les images et conteneurs, mais aussi, entre autres :
À défaut d'utiliser Docker Desktop, cette extension accomplit les tâches les plus courantes, sans quitter l'éditeur de code.
Sous Linux, pour synchroniser l’heure/fuseau horaire de l’hôte à celui du conteneur (sinon il peut y avoir un décalage de 2h en Europe), on peut ajouter un volume -v /etc/localtime:/etc/localtime:ro
(ici ro
signifie read-only c'est-à-dire lecture seule)
Si le shell par défaut est trop limité, tenter d’exécuter bash
s'il est déjà inclus dans l'image, ou on peut l'installer avec un petit apt update && apt install bash
etc. Même chose pour l'éditeur vim
si vous savez comment en sortir.
docker build -t <nomimage:tag> .
docker run --name <nomducontainer> <nomimage:tag>
(+ voir autres options)docker start <nomducontainer>
(ou stop
)docker container exec -it <nomducontainer> <lacommande>
(par exemple bash
pour ouvrir un shell)docker container ls
ou docker ps -a
docker image ls
docker container rm <nomducontainer>
docker image rm <nomdelimage>
$PWD
docker network create my-custom-net
et l'utiliser au run : --network=my-custom-net
docker stats
docker logs <nomducontainer>
docker port <nomducontainer>
docker top <nomducontainer>
docker diff <nomducontainer>
-d
: permet de détacher l'exécution du container du terminal courant-p
: permet de lier un port (local:container -p 8080:80
)-u
: permet de spécifier l'utilisateur+groupe d'exécution-v
: permet de déclarer un volume (local:container -v /var/path/to/mydata/mysql:/var/lib/mysql
)-e
: permet de passer/spécifier une variable d'environnement-i
: permet d'avoir un terminal interactif (stdin), par exemple pour entrer un mot de passe au prompt (souvent combiné avec t
)-t
: alloue un pseudo-tty--link
: permet de "lier" un hostname d'un container à un autre (par exemple un serveur mysql dans un 1er container mysqlserver
devient --link mysqlserver:db
dans le 2e, on utilise alors db
)--restart always
: indique au service Docker de redémarrer le container au boot et de le maintenir actif si Docker est lui-même relancéAstuces :
-m 256m
pour limiter la mémoire à 256 Mo--read-only
pour que le système de fichiers soit en lecture seule:ro
pour qu'il soit en lecture seuleRetrouvez l'intégralité de ce tutoriel en ligne sur Alsacreations.com
ManoMano est présent dans 6 pays en Europe (France, Belgique, Espagne, Italie, Royaume-Uni et Allemagne).
L’article La stratégie de ManoMano pour s’étendre en Europe est apparu en premier sur FrenchWeb.fr.
La panne survient à un très mauvais moment pour OVHcloud, qui est en train de proposer ses titres aux investisseurs dans le cadre d’une entrée en Bourse prévue pour vendredi.
L’article À quelques jours de son introduction en Bourse, OVHcloud subit une panne géante est apparu en premier sur FrenchWeb.fr.
A l'approche de la mise en application d'un nouveau volet de la Loi Agec en 2022 (Loi anti-gaspillage), le sujet de l'économie circulaire est plus que jamais au cœur des débats. C'est véritablement en 2016, avec la mise en place de la loi Garot, que la prise de conscience du gaspillage alimentaire en France a eÌteÌ mise au centre des deÌbats. Cette loi, unique au monde, a eÌteÌ un catalyseur de mise en mouvement des acteurs de la chaiÌne alimentaire pour lutter contre le gaspillage.
Un vent d'optimisme souffle sur notre économie, comme en témoigne une récente étude BPI, qui souligne que les trois quarts des dirigeants de PME estiment qu'ils auront retrouvé "à horizon 2022" leur niveau d'activité d'avant crise et 37% affirment que c'est déjà le cas. Un niveau d'activité retrouvé grâce à l'accélération du développement du e-commerce et le changement d'habitude d'achat des consommateurs, obligeant les PME à se digitaliser.
La pandémie a entrainé une évolution du comportement des consommateurs qui aujourd'hui attendent plus des marques et des distributeurs en matière de développement durable. Mais ces aspirations sont-elles compatibles avec les enjeux institutionnels de l'entreprise ?
Le e-commerce s'est transformé, ces dernières années, en un véritable réflexe pour une majorité de la population. Au plus fort de la pandémie, en 2020, 87,5% des internautes réalisaient leurs achats du quotidien en ligne (39 millions de français). En outre, la reprise du tourisme et la réouverture de certaines frontières ont notamment aidé à maintenir cette tendance (avec une tendance e-commerce de +24,9 % selon la Fevad).
Jusqu'à présent, la chaîne de valeur du luxe reposait sur un mixte clair : une communication véhiculant des notions d'excellence et de savoir-faire au sein d'univers oniriques avec, au cœur du réacteur, un produit très qualitatif et une expérience client élitiste. Mais comme tous les secteurs, le luxe est aujourd'hui rattrapé par le digital et sa cohorte de technologies. Avant de se rendre en boutique, l'expérience avec la marque s'amorce désormais en ligne. Une situation qui oblige les grandes
Avant de choisir quel type d'investissements réaliser, quelles démarches doivent être anticipées ? Et comment se créer une feuille de route qui garantira une digitalisation réussie ?
Après les difficultés rencontrées durant la crise sanitaire, les commerçants ont besoin de rebondir et de saisir toutes les opportunités du pic de fin d’année (Black Friday, Noël).
L’article [Livre Blanc] Le guide ultime pour augmenter son panier moyen est apparu en premier sur FrenchWeb.fr.
Près de 10 millions de trajets ont été réalisés via des services de mobilités en France en septembre. Si les vélos municipaux génèrent toujours la majorité des trajets, la part des services privés augmente.
Trois voies peuvent contribuer à décarboner le numérique : le serverless pour mieux mutualiser les serveurs, la conception durable pour éviter le superflu, et la conception d'applications performantes pour retarder l'achat de nouveaux devices.
De 9h10 à 9h38 ce 13 octobre, le groupe français a été touché par un incident mondial bloquant l'accès à de très nombreux sites hébergés sur ses plateformes.
Ces dernières années, l'activité numérique n'a fait que croitre et s'accélérer. Les responsables informatiques doivent augmenter considérablement la vitesse de livraison des applications et le temps de valorisation. C'est là que la technologie dite low-code prend alors tout son sens.
De 9h10 à 9h38 ce 13 octobre, le groupe français a été touché par un incident mondial bloquant l'accès à de très nombreux sites hébergés sur ses plateformes.
Jow, qui développe un service de livraison de courses alimentaires à domicile en fonction des menus des utilisateurs, lève 20 millions de dollars auprès d’Eurazeo et des investisseurs historiques Headline, DST et Stride.VC. En 2019, la startup a levé 7 millions de dollars et 1,5 million en 2018. Lancé en 2017 par Antoine Maillard, Franck …
L’article FoodTech: la startup française Jow lève 20 millions de dollars pour s’étendre aux États-Unis est apparu en premier sur FrenchWeb.fr.
À la base de l'IoT se trouve la connexion Internet. Les opérateurs télécoms ont toujours soutenu l'IoT en fournissant cette connexion rapide et fiable. Cette contribution fondamentale, bien que relativement simple, conditionne les innovations de l'IoT, régies en grande partie par les limites de la bande passante et de la vitesse offertes par l'Internet classique.
L’ERP est un stabilisateur de l’activité d’une entreprise avant d’en être un accélérateur.
L’article Ce qu’il faut savoir avant de mettre en place un ERP est apparu en premier sur FrenchWeb.fr.
The post Pricing Table Style 202 appeared first on Best jQuery.
The post Counter Style 163 appeared first on Best jQuery.
A collection of logotype fonts that you can use on logo design, branding & product presentation, with 11 different font families with distinct designs including feminine handwriting, children's font styles, grunge brush, outlined fonts & more
Have a look at this completely free tool featuring customizable geometric SVG shapes with a link to Figma included. Find out more useful graphic design tools.