echo -e 'dev-libs/apr-util\topenssl\t# htpasswd: BCRYPT algorithm not supported on this platform' >> /etc/portage/package.use
Showing posts with label gentoo. Show all posts
Showing posts with label gentoo. Show all posts
2013/11/13
gentoo: htpasswd: BCRYPT algorithm not supported on this platform
I'm making a note of it, as a google search didn't find the straightforward solution. In case you get the error "htpasswd: BCRYPT algorithm not supported on this platform" when using htpasswd -B on gentoo. The solution is to recompile apr-util with the openssl USE flag. Unfortunately it's switched off by default.
2010/03/31
The difference between rc_need, rc_use, rc_before and rc_after in gentoo
While trying to figure out why libvirtd starts before drbd (which is not good for me, because i have virtual machines on drbd, and autostarting virtual machines does not work this way) i wanted to know what is the difference between gentoo init script dependency keywords "need" "use" "before" and "after". Unfortunately i found no documentation about it anywhere, so i had to find it out myself:
I do not know what is the effect of rc_after and rc_before during shutdown.
Update: I found the documentation for baselayout-2: man 8 runscript
- rc_need: A service which uses another service will only run if the another service is running. For example nfs needs portmap, so if you start nfs, then portmap will start automatically before it. If you stop portmap, nfs will be stopped before it. If you restart portmap, nfs will be stopped before, and started after portmap.
- rc_use: A service which uses another service will be started after the another service during bootup, and stopped before the another service during shutdown. Example: sshd uses logger and net, so sshd will be started before logger starts, and stopped before logger stops. But if you restart the logger it will not restart the ssh daemon.
- rc_after: The service will be started after another service during bootup, but during shutdown it does not need to be stopped before the other service stops. Example: nfs will start after quota.
- rc_before: The service will be started before another service during bootup. Example: iptables will start before network comes up.
I do not know what is the effect of rc_after and rc_before during shutdown.
Update: I found the documentation for baselayout-2: man 8 runscript
2010/01/26
Enabling KSM on gentoo
Update: linux-headers-2.6.32 is now available in gentoo, i have updated the post to use that package, instead of patched 2.6.30. The patched linux-headers-2.6.30 is still available in the ebuild bundle if somebody needs it.
Last week I finally created some virtual machines on my home server (virt-manager is a pain to work with compared to VirtualBox), and I wanted to make sure Kernel Samepage Merging is working. I have kernel 2.6.32, CONFIG_KSM enabled in kernel, and qemu-kvm has support for it. But KSM didn't work, because /sys/kernel/mm/ksm/pages_sharing always returned 0. It turns out, that to get it working, linux-headers and also glibc needs to support KSM. KSM support appeared in 2.6.32, so you need linux-headers-2.6.32, which is now available in portage, see gentoo bug #297755. So let's make KSM work on gentoo:
First download into your local overlay two ebuilds I made for you:
(Make sure you have something like PORTDIR_OVERLAY="/usr/local/portage" in your /etc/make.conf)
Unmask the packages we want to emerge (binutils is a dependency for glibc):
Now emerge linux-headers and glibc with the KSM patch:
After this, you need to recompile qemu-kvm too. Plus emerge the ksm ebuild, because it has a nice initscript to enable ksm:
Now enable KSM:
Start some virtual machines, and examine how much memory are you saving with KSM:
You can also try out the ksmtuned daemon from fedora:
Last week I finally created some virtual machines on my home server (virt-manager is a pain to work with compared to VirtualBox), and I wanted to make sure Kernel Samepage Merging is working. I have kernel 2.6.32, CONFIG_KSM enabled in kernel, and qemu-kvm has support for it. But KSM didn't work, because /sys/kernel/mm/ksm/pages_sharing always returned 0. It turns out, that to get it working, linux-headers and also glibc needs to support KSM. KSM support appeared in 2.6.32, so you need linux-headers-2.6.32, which is now available in portage, see gentoo bug #297755. So let's make KSM work on gentoo:
First download into your local overlay two ebuilds I made for you:
- sys-libs/glibc-2.11-r1 with KSM patch from piavlo
- app-emulation/ksm package has an initscript to enable ksm, and ksmtuned daemon, all from fedora qemu rpm
cd /var/tmp/
wget -O gentoo-ksm-ebuilds.tbz2 http://sites.google.com/site/buddsite/gentoo-ksm-ebuilds.tbz2
tar xjf gentoo-ksm-ebuilds.tbz2 -C /usr/local/portage/(Make sure you have something like PORTDIR_OVERLAY="/usr/local/portage" in your /etc/make.conf)
Unmask the packages we want to emerge (binutils is a dependency for glibc):
echo '~sys-kernel/gentoo-sources-2.6.32' >> /etc/portage/package.keywords
echo '~sys-kernel/linux-headers-2.6.32' >> /etc/portage/package.keywords
echo '=sys-libs/glibc-2.11-r1' >> /etc/portage/package.keywords
echo '=sys-devel/binutils-2.20' >> /etc/portage/package.keywords
echo 'app-emulation/ksm' >> /etc/portage/package.keywordsNow emerge linux-headers and glibc with the KSM patch:
emerge -v1 linux-headers glibcAfter this, you need to recompile qemu-kvm too. Plus emerge the ksm ebuild, because it has a nice initscript to enable ksm:
emerge -v1 qemu-kvm ksmNow enable KSM:
/etc/init.d/ksm startStart some virtual machines, and examine how much memory are you saving with KSM:
echo "KSM pages shared: $(( $(cat /sys/kernel/mm/ksm/pages_sharing) * $(getconf PAGESIZE) / 1024 / 1024 ))Mb"You can also try out the ksmtuned daemon from fedora:
/etc/init.d/ksmtuned start
2009/12/11
Using proxy auto config to get around the "squid does not know IPv6 yet" limitation
I like making stuff which just works from the users perspective, and they dont have to care about how it works. But i do not like transparent proxies, diverting HTTP traffic without the applications knowing about it just does not seem to be right. But I like the idea of proxy autoconfiguration in web browsers. I did set it up a long time ago, with squid proxy, but there were some problems with it:
Well, actually squid does support IPv6, in version 3.1, but as of this writing it is still RC. The most important part of the Internet is the Web, so i'm reluctant to use RC. But we could use the PAC file, which is just a javascript code to not use proxy for IPv6 sites. I wanted to make this work when I first created the proxy autoconfig file, but I could not find a good way to test how it works, so my script always returned the same string: "
I wanted the following funcionality:
First, since I use gentoo, I wanted to create an ebuild for pactester. The packaging of pactester is a bit ugly, you'll get 1Mb of bundled dependencies and 15kb of useful code. I did put it into
The wpad.dat file should have a
So with a little experimentation I wrote the following proxy autoconfiguration script: wpad.dat
I found the following links useful:
http://kate-ward.blogspot.com/2008/11/im-up-and-running-with-ipv6.html
http://users.telenet.be/mydotcom/library/network/pac.htm
- When you go to an address with no DNS records associated with, squid displays an error page. When not using a proxy, browsers redirect you to a search page, or display a much nicer error. (I'm really not into redesigning squid error pages.)
- IPv6. Squid does not know about IPv6 yet.
Well, actually squid does support IPv6, in version 3.1, but as of this writing it is still RC. The most important part of the Internet is the Web, so i'm reluctant to use RC. But we could use the PAC file, which is just a javascript code to not use proxy for IPv6 sites. I wanted to make this work when I first created the proxy autoconfig file, but I could not find a good way to test how it works, so my script always returned the same string: "
PROXY proxy:3128; DIRECT". This means: use the proxy server at proxy:3128, and if that fails, use direct connection. Yesterday I stumbled upon pactester, so I tought I'll give it a try.I wanted the following funcionality:
- If the hostname is not resolvable, use direct.
- If the hostname resolves only to IPv4 addresses, use proxy
- If the hostname resolves only to IPv6 addresses, use direct
- If the hostname resolves to both IPv4 and IPv6 address, use direct.
First, since I use gentoo, I wanted to create an ebuild for pactester. The packaging of pactester is a bit ugly, you'll get 1Mb of bundled dependencies and 15kb of useful code. I did put it into
/usr/local/portage/net-proxy/pactester/.The wpad.dat file should have a
function FindProxyForURL(url, host), and newer Internet Exploer also supports a function FindProxyForURLEx(url, host). Here are some things to know:- Internet Explorer 8 calls the function
FindProxyForURLEx. - pactester and Google Chrome are using the
FindProxyForURLfunction - There are additional functions which you can use in your script, see pac_utils.js
- There are even more additional functions for you to use in
FindProxyForURLEx, see proxy_resolver_v8.cc - in pactester the function
dnsResolveEx()is not available - Google Chrome and Internet Explorer gives different results when calling
dnsResolve()
So with a little experimentation I wrote the following proxy autoconfiguration script: wpad.dat
I found the following links useful:
http://kate-ward.blogspot.com/2008/11/im-up-and-running-with-ipv6.html
http://users.telenet.be/mydotcom/library/network/pac.htm
2009/06/18
Slowing down ssh brute-force attempts
Once I was attending a presentation about exim. And I heard a good configuration idea: when we decide that an incoming mail is a spam, and we will not receive it, we do not send an error back to the client right away. We delay the error message for a long time (for example 60 seconds). Why is this useful? We already know the client wants to send junk mail, by keeping the connection open we are slowing his rate of sending down, he won't move on to try other servers so soon.
SSH brute force attacks are common, and everybody can see them in their logs. I wanted to apply the same principle, to slow down ssh brute force attacks. After googling around and not finding a solution I tried to find it myself. The following will be gentoo specific, I haven't tried this on other distributions yet.
Somewhere I read that this should be done in pam, which sounds reasonable. So I tried searching for "pam delay", and found
Dead end, but:
Sounds good. Read the man page. So into which file to put it? My first idea was to put it into
Note that I only added the auth optional line, the include system-remote-login lines were already there.
SSH brute force attacks are common, and everybody can see them in their logs. I wanted to apply the same principle, to slow down ssh brute force attacks. After googling around and not finding a solution I tried to find it myself. The following will be gentoo specific, I haven't tried this on other distributions yet.
Somewhere I read that this should be done in pam, which sounds reasonable. So I tried searching for "pam delay", and found
pam_delay.so module, but it's not available in gentoo. But i got a hunch:
grep delay /etc/pam.d/*
/etc/pam.d/samba:auth required pam_smbpass.so nodelay
/etc/pam.d/samba:password required pam_smbpass.so nodelay smbconf=/etc/samba/smb.conf
Dead end, but:
locate delay | grep pam
/lib/security/pam_faildelay.so
/usr/share/doc/pam-1.0.4/modules/README.pam_faildelay.bz2
/usr/share/man/man3/pam_fail_delay.3.bz2
/usr/share/man/man8/pam_faildelay.8.bz2
Sounds good. Read the man page. So into which file to put it? My first idea was to put it into
/etc/pam.d/system-remote-login, but this is a hard link to system-local-login, and I wanted to leave that alone. It leaves us with /etc/pam.d/sshd which now looks like this:
# set fail delay to 60 sec:
auth optional pam_faildelay.so delay=60000000
auth include system-remote-login
account include system-remote-login
password include system-remote-login
session include system-remote-login
Note that I only added the auth optional line, the include system-remote-login lines were already there.
Subscribe to:
Posts (Atom)