Return-Path: X-Original-To: apmail-apex-dev-archive@minotaur.apache.org Delivered-To: apmail-apex-dev-archive@minotaur.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 22D8C188CF for ; Sat, 26 Mar 2016 01:55:29 +0000 (UTC) Received: (qmail 72895 invoked by uid 500); 26 Mar 2016 01:55:29 -0000 Delivered-To: apmail-apex-dev-archive@apex.apache.org Received: (qmail 72822 invoked by uid 500); 26 Mar 2016 01:55:29 -0000 Mailing-List: contact dev-help@apex.incubator.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@apex.incubator.apache.org Delivered-To: mailing list dev@apex.incubator.apache.org Received: (qmail 72811 invoked by uid 99); 26 Mar 2016 01:55:29 -0000 Received: from pnap-us-west-generic-nat.apache.org (HELO spamd4-us-west.apache.org) (209.188.14.142) by apache.org (qpsmtpd/0.29) with ESMTP; Sat, 26 Mar 2016 01:55:29 +0000 Received: from localhost (localhost [127.0.0.1]) by spamd4-us-west.apache.org (ASF Mail Server at spamd4-us-west.apache.org) with ESMTP id 90286C0AB5 for ; Sat, 26 Mar 2016 01:55:28 +0000 (UTC) X-Virus-Scanned: Debian amavisd-new at spamd4-us-west.apache.org X-Spam-Flag: NO X-Spam-Score: -3.221 X-Spam-Level: X-Spam-Status: No, score=-3.221 tagged_above=-999 required=6.31 tests=[KAM_ASCII_DIVIDERS=0.8, KAM_LAZY_DOMAIN_SECURITY=1, RCVD_IN_DNSWL_HI=-5, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, RP_MATCHES_RCVD=-0.001] autolearn=disabled Received: from mx1-lw-eu.apache.org ([10.40.0.8]) by localhost (spamd4-us-west.apache.org [10.40.0.11]) (amavisd-new, port 10024) with ESMTP id CjER_z7UtwsT for ; Sat, 26 Mar 2016 01:55:27 +0000 (UTC) Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by mx1-lw-eu.apache.org (ASF Mail Server at mx1-lw-eu.apache.org) with SMTP id 617DD5F238 for ; Sat, 26 Mar 2016 01:55:26 +0000 (UTC) Received: (qmail 72624 invoked by uid 99); 26 Mar 2016 01:55:25 -0000 Received: from arcas.apache.org (HELO arcas) (140.211.11.28) by apache.org (qpsmtpd/0.29) with ESMTP; Sat, 26 Mar 2016 01:55:25 +0000 Received: from arcas.apache.org (localhost [127.0.0.1]) by arcas (Postfix) with ESMTP id 786D82C14DC for ; Sat, 26 Mar 2016 01:55:25 +0000 (UTC) Date: Sat, 26 Mar 2016 01:55:25 +0000 (UTC) From: "ASF GitHub Bot (JIRA)" To: dev@apex.incubator.apache.org Message-ID: In-Reply-To: References: Subject: [jira] [Commented] (APEXCORE-10) Enable non-affinity of operators per node (not containers) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 [ https://issues.apache.org/jira/browse/APEXCORE-10?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15212719#comment-15212719 ] ASF GitHub Bot commented on APEXCORE-10: ---------------------------------------- Github user tweise commented on a diff in the pull request: https://github.com/apache/incubator-apex-core/pull/250#discussion_r57507141 --- Diff: api/src/main/java/com/datatorrent/api/AffinityRule.java --- @@ -0,0 +1,211 @@ +/** + * 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 com.datatorrent.api; + +import java.io.Serializable; +import java.util.List; + +import com.datatorrent.api.DAG.Locality; + +/** + * Affinity rule specifies constraints for physical deployment of operator + * containers. There are two types of rules that can be specified: Affinity and + * Anti-affinity. Each rule contains list of operators or pair of 2 operators or + * a regex that should match at least 2 operators. Based on the type of rule, + * affinity or anti-affinity, the operators will be deployed together or away + * from each other. The locality indicates the level at which the rule should be + * applied. E.g. CONTAINER_LOCAL affinity would indicate operators Should be + * allocated within same container NODE_LOCAL anti-affinity indicates that the + * operators should not be allocated on the same node. The rule can be either + * strict or relaxed. + * + */ +public class AffinityRule implements Serializable +{ + @Override + public String toString() + { + return "AffinityRule {operatorsList=" + operatorsList + ", operatorRegex=" + operatorRegex + ", operators=" + + operators + ", locality=" + locality + ", type=" + type + ", relaxLocality=" + relaxLocality + "}"; + } + + private static final long serialVersionUID = 107131504929875386L; + + /** + * Pair of operator names to specify affinity rule + * The order of operators is not considered in this class + * i.e. OperatorPair("O1", "O2") is equal to OperatorPair("O2", "O1") + */ + public static class OperatorPair implements Serializable --- End diff -- It's fine to use pair internally, but maybe it is not needed in the API? varargs looks more appropriate. > Enable non-affinity of operators per node (not containers) > ---------------------------------------------------------- > > Key: APEXCORE-10 > URL: https://issues.apache.org/jira/browse/APEXCORE-10 > Project: Apache Apex Core > Issue Type: Task > Reporter: Amol Kekre > Assignee: Isha Arkatkar > Labels: roadmap > > The issue happens on cloud which provides virtual cores with software like Xen underneath. In effect if CPU intensive operators land up on same node we have a resource bottleneck, > Need to create an attribute that does the following > - Operators A & B should not be on same node > - Stram should use this attribute to try to get containers on different node > It is understood that the user is making an explicit choice to use NIC instead of stream local optimization -- This message was sent by Atlassian JIRA (v6.3.4#6332)