Profile-sync-daemon (Русский)
Contents
Преимущества psd (Profile-sync-daemon)
Запуск этого демона необходим для достижения двух целей:
- Уменьшение износа жесткого диска.
- Увеличение скорости работы браузера.
Профили, кэш, и прочие пользовательские данные браузера переносятся с помощью psd в tmpfs, соответственно операции ввода/вывода браузеров перенаправляются в оперативную память. Таким образом, уменьшается износ жесткого диска, повышается отказоустойчивость и скорость работы браузера: время доступа к оперативной памяти составляет порядка наносекунд, в свою очередь, время доступа обычного жесткого диска приблизительно в 1,000,000 раз выше и составляет порядка миллисекунд.
Поддерживаемые браузеры
В настоящее время следующие браузеры поддерживаются:
- Chromium
- conkerorAUR[broken link: package not found]
- Firefox (all flavors including stable, beta, and aurora)
- firefox-trunk: Только в Ubuntu
- google-chromeAUR
- google-chrome-betaAUR
- heftig's version of Aurora: Только в Arch Linux
- Midori
- Opera
- opera-nextAUR[broken link: package not found]
- Qupzilla
Установка и настройка
profile-sync-daemonAUR доступен для скачивания в AUR. Установка и сборка происходит как с другими пакетами.
Редактируем /etc/psd.conf
Редактируем содержимое /etc/psd.conf
, указывая с какими пользователями будет работать psd.
Пример:
# List users separated by spaces whose browser(s) profile(s) will get symlinked # and sync'ed to tmpfs. # Do NOT list a user twice! USERS="facade happy"
Опционально можно раскомментировать строку BROWSERS и вписать браузеры, которые будут синхронизироваться с tmpfs. Если оставить эту строку закомментированной (по умолчанию), то все поддерживаемые профили браузеров будут синхронизироваться, если они существуют.
Например: Допустим что Chromium, Opera и Midori установлены, но необходимо чтобы только Chromium и Opera синхронизировались с tmpfs так как пользователь использует Midori в качестве запасного браузера и пользуется им редко:
# List browsers separated by spaces to include in the sync. Useful if you do not # wish to have all possible browser profiles sync'ed. # # Possible values: # chromium # conkeror.mozdev.org # firefox # firefox-trunk # google-chrome # heftig-aurora # midori # opera # opera-next # qupzilla # # If the following is commented out (default), then all available/supported # browsers will be sync'ed, separated by comma BROWSERS="chromium opera"
Использование psd
Проверка конфигурации
Скрипт profile-sync-daemon может быть вызван с опцией 'parse' для проверки конфигурации. При этом будет отображен список профилей, которые будут синхронизироваться psd на основе данных конфигурационного файла /etc/psd.conf
. Пример вывода скрипта:
$ profile-sync-daemon parse Profile-sync-daemon v5.24 psd will manage the following per /etc/psd.conf settings: browser/psname: chromium/chromium owner/group: facade/users sync target: /home/facade/.config/chromium tmpfs dir: /tmp/facade-chromium profile size: 81M browser/psname: firefox/firefox owner/group: facade/users sync target: /mnt/data/docs/facade/mozilla/firefox/1Zp9V43q.banking tmpfs dir: /tmp/facade-firefox-1Zp9V43q.banking profile size: 5.9M browser/psname: firefox/firefox owner/group: facade/users sync target: /mnt/data/docs/facade/mozilla/firefox/obg67zqQ.proxy tmpfs dir: /tmp/facade-firefox-obg67zqQ.proxy profile size: 17M
Как показано в выводе и указано выше, если в массиве BROWSERS не задан конкретный список браузеров, psd будет синхронизировать все профили поддерживаемых браузеров, которые он сможет найти для данного пользователя(-ей).
Запуск psd для синхронизации профилей
Не следует вызывать /usr/bin/profile-sync-daemon
напрямую. Вместе с psd предоставляются файлы сервиса и таймер для systemd, и следует использовать только их для запуска psd. Сервис и таймер должны запускаться вместе. Таймер периодически обновляет копии профилей на жестком диске из tmpfs, по умолчанию это происходит один раз в час. Если не вызвать таймер, профиль на диске будет обновлен только при корректном завершении работы системы, соответственно, при аварийном завершении на диске останется устаревшая копия профиля.
Запустите сервисы psd
и psd-resync
и активируйте их на запуск/останов при загрузке/выключении (рекомендуется):
$ systemctl start psd.service psd-resync.service $ systemctl enable psd.service psd-resync.service
Все браузеры, чьи профили будут перенесены в tmpfs, должны быть закрыты при запуске сервисов.
Установка частоты синхронизации (опционально)
Предоставленный с пакетом таймер настроен на синхронизацию с интервалом в один час. Пользователь может легко установить другой желаемый интервал, редактируя файл установок таймера. В примере ниже таймер установлен на сихронизацию с интервалом в 10 минут.
/etc/systemd/system/psd-resync.timer.d/frequency.conf
[Unit] Description=Timer for Profile-sync-daemon - 10min [Timer] # Empty value resets the list of timers OnUnitActiveSec= OnUnitActiveSec=10min
См. man systemd.timer
для получения дополнительной информации о настройке таймеров.
Caveats for Firefox and Heftig's Aurora ONLY
The way psd keeps track of browser profiles and sync targets requires users to have a unique name as the last directory for all profiles in their respective $HOME/.mozilla/browser/profiles.ini
files. psd will check when it is called to run for this and refuse if this rule is not satisfied. The following is an example of a BAD profile that will fail the the test. Note that although each full path is unique, they both end in the same name! Again, the user must modify the profiles.ini
and the corresponding directory on the filesystem to correct this in order to use psd.
~/.mozilla/firefox/profiles.ini
[General] StartWithLastProfile=1 [Profile0 for user facade] Name=normal IsRelative=0 Path=/mnt/data/docs/facade/mozilla/firefox/myprofile.abc Default=1 [Profile1 for user happy] Name=proxy IsRelative=0 Path=/mnt/data/docs/happy/mozilla/firefox/myprofile.abc
FAQ
Q1. My system crashed and didn't sync back. What do I do?
Odds are the "last good" backup of your browser profiles is just fine still sitting happily on your filesystem. Upon restarting psd
(on a reboot for example), a check is preformed to see if the symlink to the tmpfs copy of your profile is invalid. If it is invalid, psd will snapshot the "last good" backup before it rotates it back into place. This is more for a sanity check that psd did no harm and that any data loss was a function of something else.
Q2. Where can I find this snapshot?
It depends on the browser. You will find the snapshot in the same directory as the browser profile and it will contain a date-time-stamp that corresponds to the time at which the recovery took place. For example, chromium will be ~/.config/chromium-backup-crashrecovery-20130912_153310
-- of course, the date_time suffix will be different for you.
Q3. How can I restore the snapshot?
- Stop
psd
. - Confirm that there is no symlink to the tmpfs browser profile directory. If there is, psd did not stop correctly for other reasons.
- Move the "bad" copy of the profile to a backup (don't blindly delete anything).
- Copy the snapshot directory to the name that browser expects.
Example using Chromium:
mv ~/.config/chromium ~/.config/chromium-bad cp -a ~/.config/chromium-backup-crashrecovery-20130912_153310 ~/.config/chromium
At this point you can launch chromium which will use the backup snapshot you just copied into place. If all is well, close the browser and restart psd and psd-resync (if using systemd). You may safely delete ~/.config/chromium-backup-crashrecovery-20130912_153310
at this point.
Support
Post in the discussion thread with comments or concerns.
PSD on other distros
psd is a bash script and should therefore run on any Linux distro. Below is a list of distros known to package psd, and a link to download their respective packages.
Distro | Default Init System | Link to Package |
---|---|---|
Arch | Systemd | AUR. |
Chakra | Systemd | CCR. |
Debian | Upstart | Graysky's PPA. See instruction below. |
Exherbo | Systemd | In official repos. |
Fedora | Systemd | In official repos. |
Gentoo | OpenRC | In official repos. |
Mint | Upstart | Graysky's PPA. See instruction below. |
OpenSUSE | Upstart | Packaged by Overman79. |
Ubuntu | Upstart | Graysky's PPA, See instruction below. |
Void | Systemd | In official repos. |
Debian
To add the PPA (personal package archive) to your Debian (tested on Squeeze) system, and to install psd:
# echo "deb http://ppa.launchpad.net/graysky/utils/ubuntu quantal main" > /etc/apt/sources.list.d/graysky.list # echo "deb-src http://ppa.launchpad.net/graysky/utils/ubuntu quantal main" >> /etc/apt/sources.list.d/graysky.list # apt-key adv --keyserver keyserver.ubuntu.com --recv-keys FF7F9516 # apt-get update # apt-get install profile-sync-daemon
Mint and Ubuntu
To add the PPA (personal package archive) to your Ubuntu (packages available for Lucid and newer) system, and to install psd:
$ sudo add-apt-repository ppa:graysky/utils $ sudo apt-get update $ sudo apt-get install profile-sync-daemon