mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-12 14:29:28 +00:00
16118c2bcb
This server impliments an RPC-based file transfer protocol that allows an NIS slave server to copy a raw map database file from an NIS master. The goal here is to speed up the transfer of very large maps. If you have, for example, an NIS password database with 30,000 records in it, it can take around 8 to 10 minutes to regenerate it (four hash databases are created). As it stands now, ypxfr(8) transfers a map by sucking all the records from ypserv(8) on the master using yp_all() and writing them to a new database using the db(3) library. This adds up to another 8 to 10 minutes, per slave. With as the number of slaves increases, this latency becomes prohibitive. With rpc.ypxfrd, all the slave has to do is copy the already-built hash database file from the master and move it into place. Even with a multi-megabyte file, this reduces the master to slave transfer time to well under a minute. (This is using TCP.) Access restrictions are applied using the same mechanism as in ypserv: you can control access using /var/yp/securenets, and the server will not transmit the master.passwd.* maps unless the transfer request originates on a reserved port. Note: this server is based on my hastily contrived protocol and is _NOT_ compatible with Sun's protocol of the same name. It can't be compatible for a couple of reasons. For one thing, Sun's protocol has not been published anywhere that I know of. It is not included in any of the SunRPC source distributions that I've been able to find. Second, Sun's NIS v2 code uses old style ndbm maps while FreeBSD uses Berkeley DB. The file formats are incompatible, so being able to transfer maps between FreeBSD and SunOS hosts wouldn't do any good anyway. (You could always port the FreeBSD NIS code to SunOS if you really wanted to do it. :) (There's also the little fact that SunOS/SPARC is big-endian and FreeBSD/i386 is little-endian. Berkeley DB can handle byte ordering differences; ndbm probably can't.)
37 lines
862 B
Makefile
37 lines
862 B
Makefile
# $Id: Makefile,v 1.4 1996/06/03 04:48:32 wpaul Exp $
|
|
|
|
PROG= rpc.ypxfrd
|
|
SRCS= ypxfrd_svc.c ypxfrd_server.c yp_error.c \
|
|
ypxfrd_xdr.c yp_access.c ypxfrd_main.c
|
|
|
|
RPCDIR= ${.CURDIR}/../../include/rpcsvc
|
|
|
|
.PATH: ${.CURDIR}/../../usr.sbin/ypserv
|
|
|
|
MAN8= rpc.ypxfrd.8
|
|
|
|
CFLAGS+= -I. -DXFRBLOCKSIZE=65535
|
|
|
|
LDADD+=-lrpcsvc
|
|
|
|
CLEANFILES= ypxfrd_svc.c ypxfrd.h
|
|
|
|
RPCGEN= rpcgen -I -C
|
|
|
|
# We need to remove the 'static' keyword from _rpcsvcstate so that
|
|
# ypxfrd_main.c can see it.
|
|
ypxfrd_svc.c: ${RPCDIR}/ypxfrd.x ypxfrd.h
|
|
rm -f ${.TARGET}
|
|
${RPCGEN} -m ${RPCDIR}/ypxfrd.x | \
|
|
sed s/"static int _rpcsvcstate"/"int _rpcsvcstate"/g > ${.TARGET}
|
|
|
|
# ypxfrd_xdr.c: ${RPCDIR}/ypxfrd.x ypxfrd.h
|
|
# rm -f ${.TARGET}
|
|
# ${RPCGEN} -c -o ${.TARGET} ${RPCDIR}/ypxfrd.x
|
|
|
|
ypxfrd.h: ${RPCDIR}/ypxfrd.x
|
|
rm -f ${.TARGET}
|
|
${RPCGEN} -h -o ${.TARGET} ${RPCDIR}/ypxfrd.x
|
|
|
|
.include <bsd.prog.mk>
|