All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.ignite.hadoop.fs.IgniteHadoopIgfsSecondaryFileSystem Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.ignite.hadoop.fs;

import org.apache.ignite.IgniteCheckedException;
import org.apache.ignite.IgniteException;
import org.apache.ignite.IgniteFileSystem;
import org.apache.ignite.igfs.IgfsBlockLocation;
import org.apache.ignite.igfs.IgfsFile;
import org.apache.ignite.igfs.IgfsPath;
import org.apache.ignite.igfs.IgfsUserContext;
import org.apache.ignite.igfs.secondary.IgfsSecondaryFileSystem;
import org.apache.ignite.igfs.secondary.IgfsSecondaryFileSystemPositionedReadable;
import org.apache.ignite.internal.GridKernalContext;
import org.apache.ignite.internal.IgniteEx;
import org.apache.ignite.internal.processors.hadoop.HadoopClassLoader;
import org.apache.ignite.internal.processors.hadoop.HadoopCommonUtils;
import org.apache.ignite.internal.processors.hadoop.delegate.HadoopDelegateUtils;
import org.apache.ignite.internal.processors.hadoop.delegate.HadoopIgfsSecondaryFileSystemDelegate;
import org.apache.ignite.lang.IgniteOutClosure;
import org.apache.ignite.lifecycle.LifecycleAware;
import org.apache.ignite.resources.IgniteInstanceResource;
import org.jetbrains.annotations.Nullable;

import java.io.OutputStream;
import java.util.Collection;
import java.util.Map;
import java.util.concurrent.Callable;

/**
 * Secondary file system which delegates calls to Hadoop {@code org.apache.hadoop.fs.FileSystem}.
 * 

* Target {@code FileSystem}'s are created on per-user basis using passed {@link HadoopFileSystemFactory}. */ public class IgniteHadoopIgfsSecondaryFileSystem implements IgfsSecondaryFileSystem, LifecycleAware { /** The default user name. It is used if no user context is set. */ private String dfltUsrName; /** Factory. */ private HadoopFileSystemFactory factory; /** Kernal context. */ private volatile GridKernalContext ctx; /** Target. */ private volatile HadoopIgfsSecondaryFileSystemDelegate target; /** * Default constructor for Spring. */ public IgniteHadoopIgfsSecondaryFileSystem() { // No-op. } /** * Simple constructor that is to be used by default. * * @param uri URI of file system. * @throws IgniteCheckedException In case of error. * @deprecated Use {@link #getFileSystemFactory()} instead. */ @Deprecated public IgniteHadoopIgfsSecondaryFileSystem(String uri) throws IgniteCheckedException { this(uri, null, null); } /** * Constructor. * * @param uri URI of file system. * @param cfgPath Additional path to Hadoop configuration. * @throws IgniteCheckedException In case of error. * @deprecated Use {@link #getFileSystemFactory()} instead. */ @Deprecated public IgniteHadoopIgfsSecondaryFileSystem(@Nullable String uri, @Nullable String cfgPath) throws IgniteCheckedException { this(uri, cfgPath, null); } /** * Constructor. * * @param uri URI of file system. * @param cfgPath Additional path to Hadoop configuration. * @param userName User name. * @throws IgniteCheckedException In case of error. * @deprecated Use {@link #getFileSystemFactory()} instead. */ @Deprecated public IgniteHadoopIgfsSecondaryFileSystem(@Nullable String uri, @Nullable String cfgPath, @Nullable String userName) throws IgniteCheckedException { setDefaultUserName(userName); CachingHadoopFileSystemFactory fac = new CachingHadoopFileSystemFactory(); fac.setUri(uri); if (cfgPath != null) fac.setConfigPaths(cfgPath); setFileSystemFactory(fac); } /** * Gets default user name. *

* Defines user name which will be used during file system invocation in case no user name is defined explicitly * through {@code FileSystem.get(URI, Configuration, String)}. *

* Also this name will be used if you manipulate {@link IgniteFileSystem} directly and do not set user name * explicitly using {@link IgfsUserContext#doAs(String, IgniteOutClosure)} or * {@link IgfsUserContext#doAs(String, Callable)} methods. *

* If not set value of system property {@code "user.name"} will be used. If this property is not set either, * {@code "anonymous"} will be used. * * @return Default user name. */ @Nullable public String getDefaultUserName() { return dfltUsrName; } /** * Sets default user name. See {@link #getDefaultUserName()} for details. * * @param dfltUsrName Default user name. * @return {@code this} for chaining. */ public IgniteHadoopIgfsSecondaryFileSystem setDefaultUserName(@Nullable String dfltUsrName) { this.dfltUsrName = dfltUsrName; return this; } /** * Gets secondary file system factory. *

* This factory will be used whenever a call to a target {@code FileSystem} is required. *

* If not set, {@link CachingHadoopFileSystemFactory} will be used. * * @return Secondary file system factory. */ public HadoopFileSystemFactory getFileSystemFactory() { return factory; } /** * Sets secondary file system factory. See {@link #getFileSystemFactory()} for details. * * @param factory Secondary file system factory. * @return {@code this} for chaining. */ public IgniteHadoopIgfsSecondaryFileSystem setFileSystemFactory(HadoopFileSystemFactory factory) { this.factory = factory; return this; } /** {@inheritDoc} */ @Override public boolean exists(IgfsPath path) { return target.exists(path); } /** {@inheritDoc} */ @Nullable @Override public IgfsFile update(IgfsPath path, Map props) { return target.update(path, props); } /** {@inheritDoc} */ @Override public void rename(IgfsPath src, IgfsPath dest) { target.rename(src, dest); } /** {@inheritDoc} */ @Override public boolean delete(IgfsPath path, boolean recursive) { return target.delete(path, recursive); } /** {@inheritDoc} */ @Override public void mkdirs(IgfsPath path) { target.mkdirs(path); } /** {@inheritDoc} */ @Override public void mkdirs(IgfsPath path, @Nullable Map props) { target.mkdirs(path, props); } /** {@inheritDoc} */ @Override public Collection listPaths(IgfsPath path) { return target.listPaths(path); } /** {@inheritDoc} */ @Override public Collection listFiles(IgfsPath path) { return target.listFiles(path); } /** {@inheritDoc} */ @Override public IgfsSecondaryFileSystemPositionedReadable open(IgfsPath path, int bufSize) { return target.open(path, bufSize); } /** {@inheritDoc} */ @Override public OutputStream create(IgfsPath path, boolean overwrite) { return target.create(path, overwrite); } /** {@inheritDoc} */ @Override public OutputStream create(IgfsPath path, int bufSize, boolean overwrite, int replication, long blockSize, @Nullable Map props) { return target.create(path, bufSize, overwrite, replication, blockSize, props); } /** {@inheritDoc} */ @Override public OutputStream append(IgfsPath path, int bufSize, boolean create, @Nullable Map props) { return target.append(path, bufSize, create, props); } /** {@inheritDoc} */ @Override public IgfsFile info(final IgfsPath path) { return target.info(path); } /** {@inheritDoc} */ @Override public long usedSpaceSize() { return target.usedSpaceSize(); } /** {@inheritDoc} */ @Override public void setTimes(IgfsPath path, long modificationTime, long accessTime) throws IgniteException { target.setTimes(path, modificationTime, accessTime); } /** {@inheritDoc} */ @Override public Collection affinity(IgfsPath path, long start, long len, long maxLen) throws IgniteException { return target.affinity(path, start, len, maxLen); } /** * @param ignite Ignite instance. */ @IgniteInstanceResource public void setIgniteInstance(IgniteEx ignite) { ctx = ignite.context(); } /** {@inheritDoc} */ @Override public void start() throws IgniteException { HadoopClassLoader ldr = ctx.hadoopHelper().commonClassLoader(); ClassLoader oldLdr = HadoopCommonUtils.setContextClassLoader(ldr); try { target = HadoopDelegateUtils.secondaryFileSystemDelegate(ldr, this); target.start(); } finally { HadoopCommonUtils.restoreContextClassLoader(oldLdr); } } /** {@inheritDoc} */ @Override public void stop() throws IgniteException { if (target != null) target.stop(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy