gpocentek..blog

février 10, 2010

Linutop OS : architecture

Filed under: FOSS — Mots-clefs :, , , — gpocentek @ 20:31

Bientôt 3 ans de travail avec Linutop, il est plus que temps que je raconte un peu le boulot fait sur le Linutop OS depuis les débuts.

Quand Fédéric Baille et Laurent Bervas m’ont contacté en 2007, suite à Solution Linux, le Linutop 1 avait fait ses premiers pas, livré avec un système Xubuntu Edgy (LiveCD) sur clé USB. C’était vaguement utilisable, pas du tout optimisé. Un gros challenge était là : partir d’une solution fonctionnelle mais lourde (1 processeur AMD LX700 et 256M de RAM), pour réussir à obtenir un système plus léger, robuste et utilisable par plus ou moins tout le monde – sans parler de la réduction du temps de boot, 3 minutes, c’est long.

La robustesse est une des idées essentielles du Linutop. Pas de pièces mobiles (disque dur, ventilateur…), un boitier solide, donc pas de casse. Le LiveCD pour l’OS était le penchant robuste du côté logiciel. Peu importe ce qui est fait durant la session, un reboot remet tout en place.

Ceci étant, on est vite limité sans persistance, et c’est d’autant plus dommage quand l’OS est fourni sur clé USB ! D’où la première modification importante, la création d’une seconde partition sur la clé, destinée à héberger les données de l’utilisateur (bookmarks, documents office, photos, j’en passe). Résultat, /dev/sda1 faisait office de système de base (via les techniques de LiveCD), l’écriture système était faite en RAM, et finalement un /dev/sda2 était monté sur /home pour la sauvegarde des documents. Plusieurs avantages à ce système :

  • un système de base intouchable et facilement restoré (reboot)
  • l’écriture des logs et données de fonctionnement de l’OS en RAM limitent l’usure de la clé USB
  • un formattage de la seconde partition restaure la session utilisateur de base

Cette utilisation d’un système de base (à base de squashfs + unionfs à l’époque) sur une partition, et de gestion des données sur la seconde est encore aujourd’hui utilisée, avec des évolutions.

Parmi ces évolutions, la persistance complète. Certains utilisateurs de Linutops ont voulu ajouter des logiciels, ou modifier les configurations sytème par défaut. Problème : comment faire quand tout est écrit en RAM ? Solution : ne plus écrire en RAM :)

Le mode persistant du Linutop est une simple extension du principe d’unionfs, en unifiant un système en squashfs avec une partition physique. Cette fois la partition sda2 contient les changements faits au système de base, y compris les données utilisateur. Le passage d’un mode à l’autre est possible (moyennant un reboot), et les données utilisateur conservées. Évidemment cette solution éloigne un peu l’OS de son idée première : la robustesse. L’OS réagit comme un OS standard, si sa configuration n’est pas bonne, il ne bootera pas. La solution de restauration est pourtant toujours possible, puisque le système de base est toujours contenu dans un fichier squashfs indisponible en écriture. Une option de restauration au boot a été ajoutée pour pouvoir simplement rétablir le système initial.

La dernière évolution a été un retour au concept de base. La persistance permettait plus de souplesse, mais apportait ses problèmes. Par sa « puissance » le Linutop implique une mono-utilisation du système (kiosk web, affichage, monitoring). C’est d’autant plus vrai que ce système s’adresse plus à un marché professionnel que consumer. Avoir une possibilité de figer le système dans une configuration est apparue nécessaire, et en accord avec l’idée première du Linutop. Le passage d’unionfs à aufs a fortement facilité l’ajout d’une 3ème couche au système d’unification, c’était le grand retour le la RAM. Le Linutop Lock superpose 3 parties distinctes du système :

  • le système de base (squashfs)
  • la configuration système et utilisateur (2nde parition de la clé)
  • la couche d’écriture  (RAM)

Le principe du Linutop Lock est simplement celui d’un LiveCD auquel on a ajouté une couche de configuration modifiable (configuration au sens large, l’ajout/suppression d’applications est aussi possible). Ce mode est idéal pour placer la machine à disposition d’utilisateurs de non-confiance (pour un kiosk internet par exemple). Si jamais l’utilisateur arrive à endommager le système, les dégats ne sont présents qu’en RAM, et un reboot suffit à tout restaurer. Résultat : 0 maintenance du matériel, 0 maintenance du système.

Un autre élément qu’a apporté ce système de partitionnement est une simplicité de déploiement. La plupart des clients Linutop déploient des machines sur de nombreux sites, systématiquement avec la même configuration. Des outils simplissimes d’utilisation permettent en 2 clics (ou une commande, je reste un geek quand même) de dupliquer intégralement un système sur clé USB bootable. L’opération est faisable en sens inverse bien évidemment. 1 Linutop maître est configuré, dupliqué sur une clé USB, et cette clé contenant le système bootable est utilisée comme source d’installation pour tous les autres Linutop ! Idéal pour diffuser une nouvelle version, ou une clé de restauration à des dizaines de sites. L’automatisation du « flashage » du disque interne permet à n’importe quel utilisateur de faire une installation d’un système préconfiguré en 3 minutes. Pas de prise de main à distance, pas de déplacement, et des connaissances plus que minimum nécessaires pour installer (je pense qu’à peu près tout le monde peut brancher une clé USB et appuyer sur le bouton de power !).

Le matériel Linutop a vraiment été conçu pour réduire les coûts de maintenance, son OS a suivi la même voie, et je pense que le résultat n’est pas mauvais :)

Parallèlement au développement de l’architecture, celui de l’interface a été le résultat de nombreuses réflexions sur ce que l’utilisateur attend en démarrant son Linutop. Plus du détails dans un prochain post…

avril 8, 2009

Misc news

Filed under: FOSS — Mots-clefs :, , , — gpocentek @ 16:24

News en vrac de tous fronts :

  • le Linutop 3 est dispo (yay \o/), et le Linutop OS 3.0 est sur le point de sortir ;
  • Solutions Linux avec Linutop s’est bien passé, on a rencontré pas mal de monde intéressant (ça a été un vrai plaisir de passer un peu de temps avec Christophe et Didier au passage) ;
  • Ulteo OVD 1.0 rc2 est également sorti, de manière discrète. N’hésitez pas à tester ! La finale devrait arriver dans les jours ou semaines qui viennent ;
  • pour l’occasion j’ai eu la joie de compiler et patcher un programme Windows pour la première fois de ma vie. Après 3 jours de setup de l’OS…
  • ça bouge sur u-classroom, un grand merci à illovae pour l’organisation des cours tty. J’ai entendu dire que skateinmars prépare un cours sur Ruby. Avis aux amateurs ;
  • j’essaie de trouver l’énergie pour préparer un TP autotools pour ma part (didrocks devait le faire mais bon… :p)
  • la nouvelle gestion du recovery après crash sur firefox 3.[15] est bien foutue, moins il y a de popups mieux je me sens ;
  • Thunderbird 3.0 utilise des onglets (mr_pouit ne voit pas l’intérêt mais il est d’humeur négative en ce moment, il passe trop de temps sous Windows) !

octobre 13, 2008

Misc news

Filed under: FOSS — Mots-clefs :, — gpocentek @ 19:21

Quelques news en vrac :

  • Olivier Fourdan a repris une partie du code de Xfkc pour l’intégrer dans le plugin de config du clavier Xfce. Yay ! Je vais probablement abandonner le développement, qui n’était de toute manière plus très actif.
  • Linutop OS 2.2.2 devrait sortir d’ici peu (un jour je ferai un post sur mon taff chez Linutop, promis). Une beta/rc/whatever est dispo en ligne of course (cf notre wiki pour les updates).
  • Regardez ce qui se passe chez Ulteo, il devrait y avoir des news sympas d’ici peu.
  • OpenOffice 3 est sorti, vous pouvez le tester sans l’installer sur le bureau en ligne Ulteo (faudra que je parle de ce que je fais là bas aussi…).
  • J’ai mis en place un wiki avec quelques code snippets, sorte de mémo un peu en vrac pour le moment. Je m’en servirai peut être pour préparer des potentiels cours pour la classroom. Si vous avez des choses à ajouter, allez-y (mais pas d’ajouts du genre « installer google earth sous Hardy » s’il-vous-plaît-merci).

Ce sera tout pour ce soir.

mars 14, 2008

Petit tour sous OpenBSD (step 1)

Filed under: FOSS — Mots-clefs :, — gpocentek @ 17:24

gapz nous parle d’OpenBSD sur #u-classroom depuis des lustres, et n’étant pas loin d’être aussi geek que lui, j’ai tenté une installation sur mon Linutop 2. Et vous savez quoi ? Ca fonctionne ! La mise en marche est assez facile par boot PXE puis installation via le net (non, y’a pas d’installeur graphique :p). Reste à apprendre comment ça fonctionne.

Vous me direz, « je m’en fous », et vous aurez raison, c’est juste un p’tit post pour faire tourner php et sql sur le serveur. Ceci dit je préparerai sûrement un tuto pour u-classroom dès que j’aurai un peu de temps…

PS copinage : allez lire le blog de mr_pouit, il écrit des trucs intelligents ce petit.

janvier 28, 2008

Solutions Linux 2008

Filed under: FOSS — Mots-clefs :, , — gpocentek @ 11:52

Je serai à solutions linux cette semaine, avec mes collègues de Linutop. Si vous êtes dans le coin passez dire bonjour ;)

Powered by WordPress