HDFS-6934. Revert files accidentally committed.
(cherry picked from commit5b1dfe78b8
) (cherry picked from commit5dbd27f8b4
)
This commit is contained in:
parent
a9f31af29c
commit
e8d77593fa
|
@ -869,8 +869,7 @@ public class NativeIO {
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public static void copyFileUnbuffered(File src, File dst) throws IOException {
|
public static void copyFileUnbuffered(File src, File dst) throws IOException {
|
||||||
if ((nativeLoaded) &&
|
if ((nativeLoaded) && (Shell.WINDOWS || Shell.LINUX)) {
|
||||||
(Shell.WINDOWS || (Shell.isLinuxSendfileAvailable))) {
|
|
||||||
copyFileUnbuffered0(src.getAbsolutePath(), dst.getAbsolutePath());
|
copyFileUnbuffered0(src.getAbsolutePath(), dst.getAbsolutePath());
|
||||||
} else {
|
} else {
|
||||||
FileUtils.copyFile(src, dst);
|
FileUtils.copyFile(src, dst);
|
||||||
|
|
|
@ -377,117 +377,6 @@ abstract public class Shell {
|
||||||
return winUtilsPath;
|
return winUtilsPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class LinuxKernelVersion implements Comparable<LinuxKernelVersion>{
|
|
||||||
private final short major;
|
|
||||||
private final short minor;
|
|
||||||
private final short revision;
|
|
||||||
|
|
||||||
public LinuxKernelVersion(short major, short minor, short revision) {
|
|
||||||
this.major = major;
|
|
||||||
this.minor = minor;
|
|
||||||
this.revision = revision;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parse Linux kernel version string from output of POSIX command 'uname -r'
|
|
||||||
* @param version version string from POSIX command 'uname -r'
|
|
||||||
* @return LinuxKernelVersion
|
|
||||||
* @throws IllegalArgumentException
|
|
||||||
*
|
|
||||||
* Note:
|
|
||||||
* On CentOS 5.8: '2.6.18-308.24.1.el5'
|
|
||||||
* On Ubuntu 14: '3.13.0-32-generic'
|
|
||||||
*/
|
|
||||||
public static LinuxKernelVersion parseLinuxKernelVersion(String version)
|
|
||||||
throws IllegalArgumentException {
|
|
||||||
if (version == null) {
|
|
||||||
throw new IllegalArgumentException();
|
|
||||||
}
|
|
||||||
String parts[] = version.split("-")[0].split("\\.");
|
|
||||||
if (parts.length != 3) {
|
|
||||||
throw new IllegalArgumentException(version);
|
|
||||||
}
|
|
||||||
short major = Short.parseShort(parts[0]);
|
|
||||||
short minor = Short.parseShort(parts[1]);
|
|
||||||
short revision = Short.parseShort(parts[2]);
|
|
||||||
return new LinuxKernelVersion(major, minor, revision);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int compareTo(LinuxKernelVersion o) {
|
|
||||||
if (this.major == o.major) {
|
|
||||||
if (this.minor == o.minor) {
|
|
||||||
return this.revision - o.revision;
|
|
||||||
} else {
|
|
||||||
return this.minor - o.minor;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return this.major - o.major;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(Object other) {
|
|
||||||
if (this == other) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (!(other instanceof LinuxKernelVersion)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return compareTo((LinuxKernelVersion) other) == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return String.format("%d.%d.%d", major, minor, revision);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode(){
|
|
||||||
int hash = 41;
|
|
||||||
hash = (19 * hash) + major;
|
|
||||||
hash = (53 * hash) + minor;
|
|
||||||
hash = (29 * hash) + revision;
|
|
||||||
return hash;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* sendfile() API between two file descriptors
|
|
||||||
* is only supported on Linux Kernel version 2.6.33+
|
|
||||||
* according to http://man7.org/linux/man-pages/man2/sendfile.2.html
|
|
||||||
*/
|
|
||||||
public static final boolean isLinuxSendfileAvailable = isLinuxSendfileSupported();
|
|
||||||
private static LinuxKernelVersion minLkvSupportSendfile =
|
|
||||||
new LinuxKernelVersion((short)2, (short)6, (short)33);
|
|
||||||
|
|
||||||
private static boolean isLinuxSendfileSupported() {
|
|
||||||
if (!Shell.LINUX) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
ShellCommandExecutor shexec = null;
|
|
||||||
boolean sendfileSupported = false;
|
|
||||||
try {
|
|
||||||
String[] args = {"uname", "bash", "-r"};
|
|
||||||
shexec = new ShellCommandExecutor(args);
|
|
||||||
shexec.execute();
|
|
||||||
String version = shexec.getOutput();
|
|
||||||
LinuxKernelVersion lkv =
|
|
||||||
LinuxKernelVersion.parseLinuxKernelVersion(version);
|
|
||||||
if (lkv.compareTo(minLkvSupportSendfile) > 0) {
|
|
||||||
sendfileSupported = true;
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
LOG.warn("isLinuxSendfileSupported() failed unexpected: " + e);
|
|
||||||
} finally {
|
|
||||||
if (LOG.isDebugEnabled()) {
|
|
||||||
LOG.debug("uname exited with exit code "
|
|
||||||
+ (shexec != null ? shexec.getExitCode() : "(null executor)"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return sendfileSupported;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final boolean isSetsidAvailable = isSetsidSupported();
|
public static final boolean isSetsidAvailable = isSetsidSupported();
|
||||||
private static boolean isSetsidSupported() {
|
private static boolean isSetsidSupported() {
|
||||||
if (Shell.WINDOWS) {
|
if (Shell.WINDOWS) {
|
||||||
|
|
|
@ -165,24 +165,4 @@ public class TestShell extends TestCase {
|
||||||
assertEquals(2, command.getRunCount());
|
assertEquals(2, command.getRunCount());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testLinuxKernelVersion() throws IOException {
|
|
||||||
Shell.LinuxKernelVersion v2_6_18 =
|
|
||||||
new Shell.LinuxKernelVersion((short)2, (short)6, (short)18);
|
|
||||||
Shell.LinuxKernelVersion v2_6_32 =
|
|
||||||
new Shell.LinuxKernelVersion((short)2, (short)6, (short)32);
|
|
||||||
assertTrue(v2_6_18.compareTo(v2_6_32) < 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testParseLinuxKernelVersion() throws Exception {
|
|
||||||
String centOs58Ver = new String("2.6.18-308.24.1.el5");
|
|
||||||
String ubuntu14Ver = new String("3.13.0-32-generic");
|
|
||||||
Shell.LinuxKernelVersion lkvCentOs58 =
|
|
||||||
Shell.LinuxKernelVersion.parseLinuxKernelVersion(centOs58Ver);
|
|
||||||
Shell.LinuxKernelVersion lkvUnbuntu14 =
|
|
||||||
Shell.LinuxKernelVersion.parseLinuxKernelVersion(ubuntu14Ver);
|
|
||||||
assertTrue(lkvUnbuntu14.compareTo(lkvCentOs58) > 0);
|
|
||||||
assertFalse(lkvUnbuntu14.equals(lkvCentOs58));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue