No hay diferencia. El sysctl
comando en Linux escribe directamente en los archivos /proc/sys
. Este fragmento del código fuente lo sysctl
demuestra:
/*
* Write a sysctl setting
*/
static int WriteSetting(const char *setting)
{
/* ... */
/* used to open the file */
tmpname = xmalloc(equals - name + 1 + strlen(PROC_PATH));
strcpy(tmpname, PROC_PATH);
strncat(tmpname, name, (int) (equals - name));
tmpname[equals - name + strlen(PROC_PATH)] = 0;
/* change . to / */
slashdot(tmpname + strlen(PROC_PATH), '.', '/');
/* ... */
fp = fopen(tmpname, "w");
/* some error checking ... */
rc = fprintf(fp, "%s\n", value);
/* ... */
}
Si desea algo permanente, debe editar /etc/sysctl.conf
o agregar un archivo en /etc/sysctl.d
(p /etc/sysctl.d/99-disable-ip-forwarding.conf
. Ej. ) Que contenga:
# Disable IP packet forwarding
net.ipv4.ip_forward = 0
Por cierto, algunas distribuciones ya lo desactivan explícitamente por defecto. Por ejemplo, RHEL <= 6 o Fedora <= 15 tienen esto en /etc/sysctl.conf
:
# Controls IP packet forwarding
net.ipv4.ip_forward = 0
Fedora 20 ya no lo deshabilita explícitamente. No hay configuración de reenvío en /etc/sysctl.conf
, /etc/sysctl.d/
o /usr/lib/sysctl.d/
.