You are not logged in.
Hi ! I've just written an ugly daemon script to relocate firefox profiles directory to a tmpfs !
http://aur.archlinux.org/packages.php?ID=48746
I know, it does the same as firefox-sync, but I've used another approach : the sync is made at boot and stop time with a small daemon script (though it's not a real daemon).
It uses rsync and can handle multiple users.
There are several advantages :
* the copy is made only at boot and shutdown with rsync, it has no impact on firefox startup time
* a copy is always kept on the disk, and the script can recover from a crash, using the old copy
I use it since last week, and another user helped me to debug, so I think it's ready
You can add the script to your daemon array in /etc/rc.conf to use it automatically :
DAEMONS=(... @firefox-tmpfs ...)
It's easy to use :
* rc.d start firefox-tmpfs : move profiles to tmpfs
* rc.d stop firefox-tmpfs : sync profiles to your disk
* rc.d restart firefox-tmpfs : ...
* rc.d save firefox-tmpfs : sync your profile to your disk (just in case), but do not stop using tmpfs
You can find firefox-tmpfs-daemon on AUR : http://aur.archlinux.org/packages.php?ID=48746
I hope it will help you, I'd be happy to get some feedback
Last edited by scullder (2011-05-14 13:41:44)
Offline
I test this. Work fine.
Offline
Can i set an hourly cron job restart firefox-tmpfs?
I'm asking because i strongly use hibernation on my netbook, but 1/10 of the times it doesn't work and i'm forced to shutdown it "unproperly", so a 'sync online ' (red: while firefox is open/the profile in use) feature would be good.
thanks!
-edit-
Here's my firefox.desktop exec line now (i'm using 'timeless' sudo):
sudo /etc/rc.d/firefox-tmpfs start ; firefox %u ; for database in ~/.mozilla/firefox/*/*.sqlite; do echo processing $database... ; sqlite3 $database 'VACUUM;'; done ; sudo /etc/rc.d/firefox-tmpfs stop
One nice addition to your 'daemon' would be the ability to select what users and what profiles to keep in tmpfs.
Anyway it works fine, great
Last edited by kokoko3k (2011-05-11 11:49:58)
Help me to improve ssh-rdp !
Retroarch User? Try my koko-aio shader !
Offline
Can i set an hourly cron job restart firefox-tmpfs?
I'm asking because i strongly use hibernation on my netbook, but 1/10 of the times it doesn't work and i'm forced to shutdown it "unproperly", so a 'sync online ' (red: while firefox is open/the profile in use) feature would be good.thanks!
I think it's a bad idea to make a restart while firefox is running, use the save target instead.
rc save firefox-tmpfs
I've never tested intensively this usage so careful
-edit-
Here's my firefox.desktop exec line now (i'm using 'timeless' sudo):sudo /etc/rc.d/firefox-tmpfs start ; firefox %u ; for database in ~/.mozilla/firefox/*/*.sqlite; do echo processing $database... ; sqlite3 $database 'VACUUM;'; done ; sudo /etc/rc.d/firefox-tmpfs stop
One nice addition to your 'daemon' would be the ability to select what users and what profiles to keep in tmpfs.
Anyway it works fine, great
I will make a config file in /etc/default. With the current version, you can change the users var in /etc/rc.d/firefox-tmpfs at line 14.
Change
users="`ls -d -c1 /home/*/.mozilla | cut -d/ -f3`"
With a list of users separated by spaces (should work)
users="username1 username2"
Thanks for testing and using
Offline
It's great. Thanks. Good contribution
Offline
I will make a config file in /etc/default.
s/default/config/
Done, the configuration file is /etc/config/firefox-tmpfs !
You can specify a list of users (var USERS), and the tmpfs directory (var TMPFS).
Offline
Sqlite's fsync is a performance-killer (affects firefox4 and liferea), so an alternative I've recently started using is:
Compile sqlite with:
CFLAGS+=" -DSQLITE_NO_SYNC"
And compile firefox4 with:
echo "ac_add_options --enable-system-sqlite" >> mozconfig
This is a reasonable alternative to throwing the sqlite databases into TMPFS.
Offline
Just a note - would it not be a good idea to put a link to this on the wiki (under Firefox of course).
Allan-Volunteer on the (topic being discussed) mailn lists. You never get the people who matters attention on the forums.
jasonwryan-Installing Arch is a measure of your literacy. Maintaining Arch is a measure of your diligence. Contributing to Arch is a measure of your competence.
Griemak-Bleeding edge, not bleeding flat. Edge denotes falls will occur from time to time. Bring your own parachute.
Offline
Sqlite's fsync is a performance-killer (affects firefox4 and liferea), so an alternative I've recently started using is:
Compile sqlite with:
CFLAGS+=" -DSQLITE_NO_SYNC"And compile firefox4 with:
echo "ac_add_options --enable-system-sqlite" >> mozconfigThis is a reasonable alternative to throwing the sqlite databases into TMPFS.
Thanks, I will test it
Just a note - would it not be a good idea to put a link to this on the wiki (under Firefox of course).
Using specific compilation options or firefox-sync / firefox-tmpfs can introduce unknown specific bugs, conflicts, etc.
In order to make a good bug report, we must use the default package / no personnal tweaks...
So I think it's a bad idea to add things like that to firefox main article on the wiki, except if you want to stress packagers of sqlite, firefox and all sqlite-dependent packages...
And there's already an article for firefox-sync with a note about firefox-tmpfs on the wiki https://wiki.archlinux.org/index.php/Firefox_Ramdisk
Offline
Can i set an hourly cron job restart firefox-tmpfs?
I'm asking because i strongly use hibernation on my netbook, but 1/10 of the times it doesn't work and i'm forced to shutdown it "unproperly", so a 'sync online ' (red: while firefox is open/the profile in use) feature would be good.thanks!
-edit-
Here's my firefox.desktop exec line now (i'm using 'timeless' sudo):sudo /etc/rc.d/firefox-tmpfs start ; firefox %u ; for database in ~/.mozilla/firefox/*/*.sqlite; do echo processing $database... ; sqlite3 $database 'VACUUM;'; done ; sudo /etc/rc.d/firefox-tmpfs stop
One nice addition to your 'daemon' would be the ability to select what users and what profiles to keep in tmpfs.
Anyway it works fine, great
Just an idea that came to my mind reading you:
If you use pm-utils for your hibernation stuff, get a look at pm-utils hooks. A simple hook that call /etc/rc.d/firefox-tmpfs save on hibernate and suspend would do the trick and would be cleaner I think.
Carpe Diem
Offline
Excellent idea. I think you should expand it to syncing other browser profiles, chromium, opera, etc. Also, make a readme.install that explains basic usage or write a wiki page (does one exist)?
Last edited by graysky (2011-12-02 19:12:29)
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
I really don't have the time for that now. But you can fork on github https://github.com/hcartiaux/archlinux- … pfs-daemon
I've thought about extending the possibilities (choice of directory synced), but anyway, it would be a new package.
I don't want to change the behavior of firefox-tmpfs-daemon, because it could disturb some users who have forgotten they were using it (I hate losing my firefox profile)
EDIT: sorry to hijack your thread. I started my own. Please post their if you wish.
Last edited by graysky (2011-12-03 11:09:39)
CPU-optimized Linux-ck packages @ Repo-ck • AUR packages • Zsh and other configs
Offline
I'm surprised you think that is a better idea than just "fixing" sqlite so as not to be so slow, as I mention above.
Especially in a "KISS" distro
Edit: I'm using sqlite 3070701 happily (their version numbers are weird) with firefox 9.0b2
Last edited by brebs (2011-12-03 02:39:23)
Offline
I'm surprised you think that is a better idea than just "fixing" sqlite so as not to be so slow, as I mention above.
Especially in a "KISS" distro
Edit: I'm using sqlite 3070701 happily (their version numbers are weird) with firefox 9.0b2
Honestly, barring getting the maintainer to change the repo build flags I think using a quick script in conjunction with the preexisting tmpfs is probably a great deal simpler in execution then recompiling not one but two programs (at least one of which can take quite a while) every time the programs in question update within a binary-based distro using differing flags than the norm. You're just trading one method of complication for another
Last edited by ZekeSulastin (2011-12-07 03:10:14)
Offline
I will ask for the removal of this package because I'm not maintaining it anymore...
If there are still users of this package, switch to the solution of graysky please
Offline